题目传送门(内部题8)


输入格式

一行三个整数$n,m,k$。


输出格式

一行一个整数表示答案。对$998244353$取模。


样例

样例输入

3 7 3

样例输出

6


数据范围与提示

对于10%的数据,$1\leqslant n,m,k\leqslant 10$。
对于40%的数据,$1\leqslant n,m,k\leqslant 1,000$。
对于70%的数据,$1\leqslant n,m,k\leqslant {10}^5$。
对于100%的数据,$1\leqslant n\leqslant {10}^9$,$1\leqslant n,k\leqslant {10}^7$。


题解

$20\%$算法:

如果$n>m$或$n<m\times k$那么一定没有方案,直接$puts("0");$即可。

时间复杂度:$\Theta(1)$。

期望的分:$0$分。

实际的分:$20$分。

$10\%$算法:

爆搜,枚举所有情况即可。

时间复杂度:$\Theta(n^k)$。

期望的分:$10$分。

实际的分:$10$分。

$40\%$算法:

考虑$DP$,设$dp[i][j]$为到第$i$个城市,一共用了$j$个建设队的方案数。

那么可以列出状态转移方程:$dp[i][j]=\sum \limits_{k=1}^{\min(k,m)}dp[i-1][j-k]$。

时间复杂度:$\Theta(n^3)$。

期望的分:$40$分。

实际的分:$40$分。

$100\%$算法:

考虑容斥,挡板法。

这个问题可以转化为,在$m$个物品中插入$n-1$个挡板,挡板不能插在一起,那么方案数就是$C_{m-1}^{n-1}$。

现在需要减去不合法的方案数,设至少有$i$个城市不合法,那么方案数就是$C_n^i\times C_{m-i\times k-1}^{n-1}$,可以理解为,我先将那$i\times k$个不合法的扔掉,再在$m-i\times k$里面选合法的即可。

利用容斥统计答案即可。

时间复杂度:$\Theta(m)$。

期望的分:$100$分。

实际的分:$100$分。


代码时刻

$20\%$算法:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int n,m,k;
  4. int main()
  5. {
  6. scanf("%d%d%d",&n,&m,&k);
  7. if(n>m||n*k<m)puts("0");
  8. return 0;
  9. }

$40\%$算法:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int dp[7000][7000];
  4. int main()
  5. {
  6. int n,m,k;
  7. scanf("%d%d%d",&n,&m,&k);
  8. for(int i=1;i<=k;i++)dp[1][i]=1;
  9. for(int i=2;i<=n;i++)
  10. for(int j=i;j<=m;j++)
  11. for(int l=1;l<=min(k,m);l++)
  12. dp[i][j]=(dp[i][j]+dp[i-1][j-l])%998244353;
  13. cout<<dp[n][m]<<endl;
  14. return 0;
  15. }

$100\%$算法:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. long long n,m,k;
  4. long long jc[100000001],qsm[100000001];
  5. long long ans;
  6. long long qpow(long long x,long long y)
  7. {
  8. long long res=1;
  9. while(y)
  10. {
  11. if(y&1)res=res*x%998244353;
  12. x=x*x%998244353;
  13. y>>=1;
  14. }
  15. return res;
  16. }
  17. void pre_work()
  18. {
  19. jc[0]=1;
  20. for(int i=1;i<=m;i++)
  21. jc[i]=1LL*jc[i-1]*i%998244353;
  22. for(int i=0;i<=m;i++)
  23. qsm[i]=qpow(jc[i],998244351)%998244353;
  24. }
  25. long long cm(long long x,long long y)
  26. {
  27. return jc[x]*qsm[y]%998244353*qsm[x-y]%998244353;
  28. }
  29. long long lucas(long long x,long long y)
  30. {
  31. if(!y)return 1;
  32. return cm(x%998244353,y%998244353)*lucas(x/998244353,y/998244353)%998244353;
  33. }
  34. int main()
  35. {
  36. scanf("%lld%lld%lld",&n,&m,&k);
  37. if(n>m||n*k<m){puts("0");return 0;}
  38. pre_work();
  39. long long flag=-1;
  40. ans=jc[m-1]*qsm[n-1]%998244353*qsm[m-n]%998244353;
  41. for(int i=1;i<=n;i++)
  42. {
  43. if(m-i*k<n)continue;
  44. ans=(ans+flag*lucas(n,i)%998244353*lucas(m-i*k-1,n-1)+998244353)%998244353;
  45. flag=-flag;
  46. }
  47. printf("%lld",(ans+998244353)%998244353);
  48. return 0;
  49. }

rp++

[CSP-S模拟测试]:建设城市(city)(组合数学+容斥)的更多相关文章

  1. 建设城市(city):组合数,容斥原理

    想模一大堆人呢.考场上AC的大仙. 估计没人想给这题好好写一个题解吧,因为它的确挺简单的... 但是它对我来说一点都不简单啊!!! 至少出题人用脚写题解的时候肯定认为这道题是送分题了 容斥,枚举至少有 ...

  2. [CSP-S模拟测试]:多维网格(组合数学+容斥)

    题目传送门(内部题138) 输入格式 输入数据第一行为两个整数$d,n$. 第二行$d$个非负整数$a_1,a_2,...,a_d$.     接下来$n$行,每行$d$个整数,表示一个坏点的坐标.数 ...

  3. 【GDOI2016模拟3.16】幂(容斥 + 模型复杂转化)

    [GDOI2016模拟3.16]幂 \(X\in[1,A],Y\in[1,B]\),问:\(x^y\)的不用取值个数. \(A,B\)都是\(10^9\)级别. 然后我们开搞. 首先,假设一个合法的\ ...

  4. HDU 6397 Character Encoding (组合数学 + 容斥)

    题意: 析:首先很容易可以看出来使用FFT是能够做的,但是时间上一定会TLE的,可以使用公式化简,最后能够化简到最简单的模式. 其实考虑使用组合数学,如果这个 xi 没有限制,那么就是求 x1 + x ...

  5. [BZOJ2839]:集合计数(组合数学+容斥)

    题目传送门 题目描述 .(是质数喔~) 输入格式 一行两个整数N,K. 输出格式 一行为答案. 样例 样例输入: 3 2 样例输出: 样例说明 假设原集合为{A,B,C} 则满足条件的方案为:{AB, ...

  6. [NOIP模拟测试7]visit 题解(组合数学+CRT+Lucas定理)

    Orz 因为有T的限制,所以不难搞出来一个$O(T^3)$的暴力dp 但我没试 据说有30分? 正解的话显然是组合数学啦 首先$n,m$可能为负,但这并没有影响, 我们可以都把它搞成正的 即都看作向右 ...

  7. 【10.3校内测试【国庆七天乐!】】【DP+组合数学/容斥】【spfa多起点多终点+二进制分类】

    最开始想的暴力DP是把天数作为一个维度所以怎么都没有办法优化,矩阵快速幂也是$O(n^3)$会爆炸. 但是没有想到另一个转移方程:定义$f[i][j]$表示每天都有值的$i$天,共消费出总值$j$的方 ...

  8. codeforces 439 E. Devu and Birthday Celebration 组合数学 容斥定理

    题意: q个询问,每一个询问给出2个数sum,n 1 <= q <= 10^5, 1 <= n <= sum <= 10^5 对于每一个询问,求满足下列条件的数组的方案数 ...

  9. 【XSY2990】树 组合数学 容斥

    题目描述 同 Comb Avoiding Trees 不过只用求一项. \(n,k\leq {10}^7\) 题解 不难发现一棵 \(n\) 个叶子的树唯一对应了一个长度为 \(2n-2\) 的括号序 ...

随机推荐

  1. 【MM系列】SAP MM模块-组织结构介绍

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP MM模块-组织结构介绍   ...

  2. 应用安全-软件安全-漏洞CVE整理

    jira ssrf CVE-2019-8451 url = url + '/plugins/servlet/gadgets/makeRequest?url=' + host + '@www.baidu ...

  3. Spring Boot系列(三) Spring Boot 之 JDBC

    数据源 类型 javax.sql.DataSource javax.sql.XADataSource org.springframework.jdbc.datasource.embedded,Enbe ...

  4. python基础-5.2装饰器

    1.了解装饰器前准备 #### 第一波 #### def foo(): print 'foo' foo #表示是函数,仅指向了函数的地址,为执行 foo() #表示执行foo函数 #### 第二波 # ...

  5. 华为交换机SOCK CPU占用率高处理方法

    问题截图: 解决方法: cpu-defend policy cpu auto-defend enable auto-defend attack-packet sample 5 auto-defend ...

  6. mybatis加载配置文件详解

    spring整合Mybatis后,SqlSessionFactory的创建由spring进行了代理,以下是SqlSessionFactory创建的流程 SqlSessionFactoryBean: p ...

  7. <每日一题> Day4:CodeForces-1042A.Benches(二分 + 排序)

    题目链接 参考代码: /* 排序 + 每次取小 #include <iostream> #include <algorithm> using namespace std; co ...

  8. 旧接口注册LED字符驱动设备(动态映射)

    #include <linux/init.h> // __init __exit #include <linux/module.h> // module_init module ...

  9. C#学习——控件

    Windows应用程序控件的基类是位于System.Windows.Forms命名空间的Control类. Control类定义了控件类的共同属性.方法和事件,其他的控件类都直接或间接到派生自这个类. ...

  10. jquery遍历table中每个td的值

    废话不说直接上: <table style="border:1px solid #ccc">        <tr>            <td&g ...