首页 > 代码库 > HDU 4704 Sum (隔板原理 + 费马小定理)
HDU 4704 Sum (隔板原理 + 费马小定理)
题目链接:
http://acm.hdu.edu.cn/showproblem.php?pid=4704
题意:
给定一个数n 将其分解,Si 表示将n拆成i个数的方案数
求sum( si ) 1<=i<=n;
分析:
隔板原理, n个木棍,n-1个缝,
分成1份则是C(n-1,0);
分成2份则是C(n-1,1);
分成3份则是C(n-1,2);
...
分成n份则是C(n-1,n-1);
ans = sum( C(n-1,i) ) (0<=i<=n-1)
=2^(n-1);
由于要取模 而且 2 与 mod 互质 ,因此可以用费马小定理来降幂
代码如下:
#include <iostream> #include <cstring> #include <cstdio> using namespace std; typedef long long LL; const int mod = 1e9+7; const int maxn = 1e5+10; char a[maxn]; LL quick_mod(LL a,LL b,LL m) { LL ans = 1; while(b){ if(b&1){ ans = ans * a % m; b--; } b>>=1; a = a * a % m; } return ans ; } LL change(char *s, LL m ) { LL ans = 0; int len = strlen(s); for(int i = 0; i < len; i++){ ans = (ans * 10 + a[i] - '0')%m; } return ans ; } int main() { while(~scanf("%s",a)){ int m = mod - 1; LL n = change(a,m); printf("%I64d\n",quick_mod(2,(n-1+m)%m,mod)); } return 0; }
HDU 4704 Sum (隔板原理 + 费马小定理)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。