题目大意:给出N(1<=N<=10^100000),求S(1)+S(2)+……S(N)对取1e9+7取模后的值。其中S(k)表示任选k个正整数使得它们之和等于N的方案数。
分析:
一开始还以为是求整数划分个数,很快发现不是的。比如N=4的时候,(1,1,2)和(1,2,1)应当作不同的方案。
考虑将N部拆分成N个1,然后对这N个1用插板法进行划分。那么总的方案就是C(n-1,0)+C(n-1,1)+……+C(n-1,n-1)=2^(n-1)
注意到这里的N非常大,而1e9+7为质数,因此可使用费马小定理降幂处理。
对于输入用字符串输入,然后同余定理处理即可。
#include<stdio.h> #include<string.h> typedef long long LL; #define mod 1000000007 char n[100005]; LL pow(LL a,LL b) { LL ans=1; while(b) { if(b&1) ans=ans*a%mod; a=a*a%mod; b>>=1; } return ans; } int main(){ LL N; int l,i; while(~scanf("%s",n)) { l=strlen(n); N=0; for(i=0;i<l;++i) N=(N*10+n[i]-'0')%(mod-1); printf("%lld\n",pow(2,(N-2+mod)%(mod-1))); } return 0; }