原文链接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)=\)

  1. 如果 $n=0 $ ,那么返回 \(1\) 。

  2. 如果 \(m = 1\) ,那么 (1) 式恒成立,答案就是 \(n!\binom{M}{n} = M^{\underline{n}}\)

  3. 否则,我们通过容斥,分类讨论(结果就是下面 (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 动态规划的更多相关文章

  1. TopCoder SRM500 Div1 1000 其他

    原文链接https://www.cnblogs.com/zhouzhendong/p/SRM500-1000.html SRM500 Div1 1000 设 \(v_1,v_2,\cdots ,v_9 ...

  2. TopCoder SRM502 Div1 500 贪心 01背包

    原文链接https://www.cnblogs.com/zhouzhendong/p/SRM502-500.html SRM502 Div1 500 好题. 首先,如果已经确定了解决所有问题的优先级, ...

  3. TopCoder 649 div1 & div2

    最近一场TC,做得是在是烂,不过最后challenge阶段用一个随机数据cha了一个明显错误的代码,最后免于暴跌rating,还涨了一点.TC题目质量还是很高的,非常锻炼思维,拓展做题的视野,老老实实 ...

  4. TopCoder SRM500 Div1 250 其他

    原文链接https://www.cnblogs.com/zhouzhendong/p/SRM500-250.html SRM500 Div1 250 题意 (看题用了半个小时--) 有 n 个人(编号 ...

  5. TopCoder SRM500 Div1 500 分治

    原文链接https://www.cnblogs.com/zhouzhendong/p/SRM500-500.html SRM500 Div1 500 没想到 double 的精度居然没有爆-- 考虑以 ...

  6. topcoder SRM712 Div1 LR

    题目: Problem Statement      We have a cyclic array A of length n. For each valid i, element i-1 the l ...

  7. TopCoder 603 div1 & div2

    div2 250pts MiddleCode 题意:s串长度为奇数时,将中间字符取掉并添加到t末尾:长度为偶数时,将中间两个较小的字符取掉并添加到末尾. 分析:直接做,学习了一下substr(s, p ...

  8. TopCoder SRM704 Div1 800 构造

    原文链接https://www.cnblogs.com/zhouzhendong/p/SRM704-800.html 题解 考虑构造一个 $n = 20$ 的图. 先把所有 $i$ 都连向 $i-1$ ...

  9. topcoder SRM642 div1 hard WheelofFortune

    题目链接:vjudge 大意:有两个人参加一场游戏,这个游戏在一个编号为\(0\text~n-1\)的轮盘上进行,一开始轮盘上的数字均为0:一共有\(m\)轮,每一轮都有一个操作参数\(s_i\),主 ...

随机推荐

  1. telnet mysql时出现:is not allowed to connect to this MySQL serverConnection closed by foreign host问题的解决

    有时候telnet一个mysql服务器的时候会出现: Host '192.168.0.1' is not allowed to connect to this MySQL serverConnecti ...

  2. C# 操作Excel加水印

    首先下载免费版的Excel组件- Spire.XLS,安装完成后在bin目录里面有需要用到的dll文件,引用到自己项目里面. 我这里全引进来了,一共就四个: 界面 效果 全部代码 private st ...

  3. java移位运算符:<<(左移)、>>(带符号右移)和>>>(无符号右移)。

    1. 左移运算符 左移运算符<<使指定值的所有位都左移规定的次数. 1)它的通用格式如下所示: value << num num 指定要移位值value 移动的位数. 左移的规 ...

  4. 访问 Confluence 6 的计划任务配置

    希望访问 Confluence 计划任务配置界面: 进入  > 基本配置(General Configuration) > 计划任务(Scheduled Jobs) 所有的计划任务将会按照 ...

  5. 找到 Confluence 6 的日志和配置文件

    找到 Confluence 的日志文件 这部分内容对 Confluence 的默认日志表现进行描述并且假设你没有对 Confluence 的默认日志配置进行修改.为了统一在不同平台中的日志输出,Con ...

  6. Confluence 6 用户目录图例 - 和 Jira 连接到 Crowd

      上面的图:Confluence, JIRA 和其他应用程序连接到 Crowd 作为用户管理. https://www.cwiki.us/display/CONF6EN/User+Managemen ...

  7. mysql数据库1

      desc 表名;  显示表结构

  8. Linux 系统根目录下各个文件夹的作用

    原文: https://blog.csdn.net/qq_26941173/article/details/78376760 /bin 系统由很多放置可执行文件的目录,但是bin目录比较特殊.因为bi ...

  9. cf1107d 映射关系

    #include<bits/stdc++.h> using namespace std; ][]; int judge(int i){ ;j<=n;j++) ][j]); ; } i ...

  10. js获取url协议、url, 端口号等信息路由信息

    以路径为 http://www.baidu.com  为例 console.log("location:"+window.location.href); >> &quo ...