TopCoder SRM502 Div1 1000 动态规划
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM502-1000.html
SRM502 Div1 1000
题意
从 [0,n-1] 中选择 k 个不同的整数,使得他们的和是 n 的倍数,求方案数。对 \(10^9+7\) 取模。
\(n\leq 10^9,k\leq 1000\)
题解
首先我们考虑从 n 个里面选择 k 个并进行排列的方案数,最终只需要除以 k! 就好了。
设 \(M=n\) ;
设 \(f(n,m,t)\) 表示 在 \(0,1,\cdots M-1\) 中任选 \(n\) 个,并使得 \((\sum_{1\leq i < n } x_i ) + t x_n \equiv 0 \pmod m\cdots (1)\) (设取的第 \(i\) 个为 \(x_i\) ) 。
则答案显然是 \(f(k,n,1)\) 。
于是我们考虑如何求解这个函数。
\(f(n,m,t)=\)
如果 $n=0 $ ,那么返回 \(1\) 。
如果 \(m = 1\) ,那么 (1) 式恒成立,答案就是 \(n!\binom{M}{n} = M^{\underline{n}}\)
否则,我们通过容斥,分类讨论(结果就是下面 (1) 的贡献减掉 (2) 的贡献)。
(1) \(x_i(i<n)\) 中可能存在与 \(x_n\) 相等的数(也可能不存在):相当于选择 \(n-1\) 个数存在 \(x_n\) 使得 \((\sum_{1\leq i < n } x_i ) + t x_n \equiv 0 \pmod m\) ,设 \(g = \gcd(t,m)\),则方案数 \(=f(n-1,g,1)\) ,对于 \(x_n\) ,我们也可以确定其取值个数,即 \(Mg/m\) 。
(2) \(x_i(i<n)\) 中存至少一个与 \(x_n\) 相等的数。则在 \(x_1\cdots x_{n-1}\) 个中任选一个和 \(x_n\) 相等,有 \(n-1\) 种可能,乘上对应的方案数 \(f(n-1,m,t+1)\) 即可。
由于我们经常要用到 \(f(a,b,1)\) ,所以我们对于 \(f(a,b,1)\) 记忆化一下,然后搜索即可。注意 \(f(a,n,1)\) 这种要特殊处理。
代码
static const int N=1005,mod=1e9+7;
int M;
int dp[N][N],Fac[N];
int Pow(int x,int y){
int ans=1;
for (;y;y>>=1,x=1LL*x*x%mod)
if (y&1)
ans=1LL*ans*x%mod;
return ans;
}
int gcd(int x,int y){
return y?gcd(y,x%y):x;
}
int f(int n,int m,int t){
if (n==0)
return 1;
if (m==1)
return Fac[n];
int g=gcd(m,t);
// sum + t * x = 0
// c(sum = 0) - c(sum = 0 && (t+1))
if (t==1){
int _m=min(m,1000+1);
if (~dp[n][_m])
return dp[n][_m];
dp[n][_m]=((1LL*f(n-1,g,1)*(M/m*g)
-1LL*f(n-1,m,t+1)*(n-1))%mod+mod)%mod;
return dp[n][_m];
}
int res=((1LL*f(n-1,g,1)*(M/m*g)
-1LL*f(n-1,m,t+1)*(n-1))%mod+mod)%mod;
return res;
}
int find(int N, int K){
M=N;
memset(dp,-1,sizeof dp);
int t=1;
Fac[0]=1;
for (int i=1;i<=K;i++){
t=1LL*t*i%mod;
Fac[i]=1LL*Fac[i-1]*(N-i+1)%mod;
}
t=Pow(t,mod-2);
int ans=1LL*t*f(K,N,1)%mod;
return ans;
}
TopCoder SRM502 Div1 1000 动态规划的更多相关文章
- TopCoder SRM500 Div1 1000 其他
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM500-1000.html SRM500 Div1 1000 设 \(v_1,v_2,\cdots ,v_9 ...
- TopCoder SRM502 Div1 500 贪心 01背包
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM502-500.html SRM502 Div1 500 好题. 首先,如果已经确定了解决所有问题的优先级, ...
- TopCoder 649 div1 & div2
最近一场TC,做得是在是烂,不过最后challenge阶段用一个随机数据cha了一个明显错误的代码,最后免于暴跌rating,还涨了一点.TC题目质量还是很高的,非常锻炼思维,拓展做题的视野,老老实实 ...
- TopCoder SRM500 Div1 250 其他
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM500-250.html SRM500 Div1 250 题意 (看题用了半个小时--) 有 n 个人(编号 ...
- TopCoder SRM500 Div1 500 分治
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM500-500.html SRM500 Div1 500 没想到 double 的精度居然没有爆-- 考虑以 ...
- topcoder SRM712 Div1 LR
题目: Problem Statement We have a cyclic array A of length n. For each valid i, element i-1 the l ...
- TopCoder 603 div1 & div2
div2 250pts MiddleCode 题意:s串长度为奇数时,将中间字符取掉并添加到t末尾:长度为偶数时,将中间两个较小的字符取掉并添加到末尾. 分析:直接做,学习了一下substr(s, p ...
- TopCoder SRM704 Div1 800 构造
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM704-800.html 题解 考虑构造一个 $n = 20$ 的图. 先把所有 $i$ 都连向 $i-1$ ...
- topcoder SRM642 div1 hard WheelofFortune
题目链接:vjudge 大意:有两个人参加一场游戏,这个游戏在一个编号为\(0\text~n-1\)的轮盘上进行,一开始轮盘上的数字均为0:一共有\(m\)轮,每一轮都有一个操作参数\(s_i\),主 ...
随机推荐
- maven:打包时报错,报’找不到符号’
参考文章:https://www.cnblogs.com/kelly-one/p/7349930.html 问题描述: 工程开发调试都没有问题,就是不能导出WAR包,用mvn clean packag ...
- 洛谷P3676 小清新数据结构题 [动态点分治]
传送门 思路 这思路好妙啊! 首先很多人都会想到推式子之后树链剖分+线段树,但这样不够优美,不喜欢. 脑洞大开想到这样一个式子: \[ \sum_{x} sum_x(All-sum_x) \] 其中\ ...
- C#的winform中控制TextBox中只能输入数字
C#的winform中控制TextBox中只能输入数字 private void textBox3_KeyPress(object sender, System.Windows.Forms.KeyPr ...
- LuoGu P1004 方格取数
题目传送门 一开始这个题我是不会的(沙华弱DP啊QwQ),后来考完试我一想,这东西怎么和数字三角形那题这么像啊? 都是自上而下,只能向下或者向右,求一个max 那么...这不就是个走两遍的数字矩阵嘛 ...
- 使用Node.js+Hexo+Github搭建个人博客(续)
一.写在前面 在我的上一篇博客<使用Nodejs+Hexo+Github搭建个人博客>中,已经介绍了如何使用 Hexo 在 Github Pages 上搭建一个简单的个人博客.该篇博文将在 ...
- 在 Linux 中自动启动 Confluence 6
在 Linux/Solaris 环境下,最好的办法是对每一个服务进行安装和配置(包括 Confluence),同时配置这些服务权限为他们所在用户需要的服务权限即可, 为实例创建一个 Confluenc ...
- Confluence 6 查看系统属性
当你添加了内存,设置了代理(proxy)或者修改了 Java 的选项,通常比较难判断系统是否已经按照你的修改进行了配置和启动.这个页面将会帮助你查看 Confluence 站点运行使用的系统属性. 你 ...
- elementui上传图片到七牛云服务器
注册七牛云 首先,注册七牛云,并且完成实名认证,完成后会在个人中心->秘钥管理中看到两个秘钥AccessKey/SecretKey 创建存储空间(必须要实名认证) 生成上传凭证 为了实现上传,我 ...
- 理解call及apply
转载自:http://www.zhihu.com/question/20289071 //call 和 apply 都是为了改变某个函数运行时的 context 即上下文而存在的,换句话说,就是为了改 ...
- python之路第二天
为何要有操作系统 为了让程序员更轻松的完成命令电脑工作而存在的,控制硬件,服务于软件. 操作系统的位置 操作系统位于软件和硬件之间.操作系统由内核(运行于内核态,控制硬件)和系统调用(运行于用户态,为 ...