博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C - Contest Setting Gym - 101982C
阅读量:2352 次
发布时间:2019-05-10

本文共 1149 字,大约阅读时间需要 3 分钟。

比较简单的一个dp,但是自己没做出来,看过大佬博客之后秒懂了

(做个好事)

他的思路先统计相同难度题目的个数(和离散化差不多),状态转移方程是这样的 dp[i][j] = dp[i - 1][j - 1] * val[i] + dp[i - 1][j];

也就是前i - 1个数挑出j个的方案数(这是之前就求出来的,相当于继承了下来),dp[i - 1][j - 1] * val[i] 这个是新增加的一道题目所带来的方案书的增加量。说的通俗一点就是:现在的 = 之前的 + 新增加的。(引用)

#include
#include
#include
#include
#include
using namespace std;typedef long long ll;const int mod = 998244353;int a[1010];ll val[1010];ll dp[1010][1010];int main(){ int n,k; cin >> n >> k; for(int i = 1; i <= n; i++) { cin >> a[i]; } sort(a + 1, a + 1 + n); int cnt = 1; int top = 1; for(int i = 2; i <= n; i++) { if(a[i] == a[i - 1]) { cnt++; } else { val[top++] = cnt; cnt = 1; } } val[top++] = cnt; memset(dp, 0, sizeof(dp)); for(int i = 0; i <= 1000; i++) { dp[i][0] = 1; } for(int i = 1; i <= top - 1; i++) { for(int j = 1; j <= k; j++) { dp[i][j] = ((dp[i - 1][j - 1] * val[i] % mod) + dp[i - 1][j]) % mod; } } cout << dp[top - 1][k] << endl; return 0;}

 

转载地址:http://snwtb.baihongyu.com/

你可能感兴趣的文章
IBM TSM磁带管理操作小记一则
查看>>
ORA-00258: NOARCHIVELOG 模式下的人工存档必须标识日志
查看>>
Java调用bat文件
查看>>
此责任无可用函数
查看>>
java获取数字和汉字
查看>>
excel Option Explicit webadi
查看>>
ICX错误
查看>>
windows Xp NTLDR is missing
查看>>
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
查看>>
Centos 6.x 安装配置MySQL
查看>>
-source 1.5 中不支持 diamond 运算 请使用 -source 7 或更高版本以启用
查看>>
jar包读取资源文件报错:找不到资源文件(No such file or directory)
查看>>
超简单:Linux安装rar/unrar工具与解压到目录示例
查看>>
Eclipse创建Maven Java8 Web项目,并直接部署Tomcat
查看>>
RedHad 7.x服务器操作记录
查看>>
BindException: Cannot assign requested address (Bind failed)解决办法
查看>>
Centos7:Docker安装Gitlab
查看>>
Kafka日志配置
查看>>
logstash 6.x 收集syslog日志
查看>>
Apche Kylin启动报错:UnknownHostException: node1:2181: invalid IPv6 address
查看>>