hdu 4767 Bell
思路:矩阵快速幂+中国剩余定理!!
查资料得到2个公式:
1) B[n+p] = B[n] + B[n+1] mod p ;
2) B[p^m+n] = m*B[n] + B[n+1] mod p .
用这两个都可以解决这个问题,第二个可以在0ms解决。
质因数分解95041567=31*37*41*43*47,用矩阵快速幂分别求出B[n]%p (p是95041567的质因子)的结果。
这样就得到5个同余等式,在用中国剩余定理求解既可。
代码如下:
#include <iostream>
#include <cstring>
#include <cstdio>
#define M 51
#define mod 95041567
#define ll __int64
using namespace std;
int p[]={,,,,},a[],bell[M][M];
struct Mat
{
int m[M][M];
};
Mat Mul(Mat a,Mat b,int n)
{
Mat ans;
for(int i=;i<n;i++)
for(int j=;j<n;j++){
ans.m[i][j]=;
for(int k=;k<n;k++)
ans.m[i][j]+=a.m[i][k]*b.m[k][j];
ans.m[i][j]%=n;
}
return ans;
}
int Pow(int n,int m)
{
Mat ans,a;
memset(ans.m,,sizeof(ans.m));
memset(a.m,,sizeof(a.m));
a.m[][m-]=a.m[][m-]=;
for(int i=;i<m-;i++) a.m[i+][i]=;
for(int i=;i<m;i++) ans.m[][i]=bell[i][i]%m;
while(n){
if(n&) ans=Mul(ans,a,m);
n>>=;
a=Mul(a,a,m);
}
return ans.m[][];
}
void init()
{
int i,j;
bell[][]=;bell[][]=;
for(i=;i<M;i++){
bell[i][]=bell[i-][i-];
for(j=;j<=i;j++) bell[i][j]=(bell[i][j-]+bell[i-][j-])%mod;
}
}
void gcd_extend(int a,int b,ll &x,ll &y)
{
if(b==){
x=;y=;
return ;
}
gcd_extend(b,a%b,x,y);
ll t=x;
x=y;
y=t-a/b*y;
}
int china()
{
ll ans=,x,y;
for(int i=;i<;i++){
int t=mod/p[i];
gcd_extend(t,p[i],x,y);
ans=(ans+a[i]*t*((x%p[i]+p[i])%p[i]))%mod;
}
return ans;
}
int main(){
int t,n;
init();
scanf("%d",&t);
while(t--){
scanf("%d",&n);
for(int i=;i<;i++)
a[i]=Pow(n,p[i]);
printf("%d\n",china());
}
return ;
}
hdu 4767 Bell的更多相关文章
- HDU 4767 Bell(矩阵+中国剩余定理)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4767 题意:给出n.求n有多少种划分集合的方式,即bell(n) 思路: #include <i ...
- 2013长春网赛1009 hdu 4767 Bell(矩阵快速幂+中国剩余定理)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4767 题意:求集合{1, 2, 3, ..., n}有多少种划分情况bell[n],最后结果bell[ ...
- HDU 4767——Bell
昨天比赛被虐的这个题目. 今天听斌牛讲过他的思路后就A掉了. 题目的意思是要你求出bell数的第n项对95041567取模. 首先,95041567=31*37*41*43*47: 然后取模就是先分别 ...
- HDU 4767
昨晚苦恼了一晚,因为即将大三了,必须要准备实习什么的事了.一般都会去公司实习吧,但是看看自己的简历,实在拿不出手,因为大一大二都在搞ACM(虽然真正搞的只有大二一年),但却没有什么成绩,又不愿意做项目 ...
- Bell(hdu4767+矩阵+中国剩余定理+bell数+Stirling数+欧几里德)
Bell Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Status ...
- Bell(矩阵快速幂+中国剩余定理)
Bell Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Status ...
- hdu 5445 Food Problem 多重背包
Food Problem Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5 ...
- hdu 5445 多重背包
Food Problem Time Limit: 3000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)To ...
- HDU 2512 一卡通大冒险(第二类斯特林数+贝尔数)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2512 题目大意:因为长期钻研算法, 无暇顾及个人问题,BUAA ACM/ICPC 训练小组的帅哥们大部 ...
随机推荐
- Android开发遇到的异常及解决办法
Android开发遇到的错误及解决方法1. Unable to resolve target 'android-7' 解决方案: 修改工程目录下的default.properties文件里的内容tar ...
- WebStorm mac 下载地址及注册码
webStorm : UserName:William ===== LICENSE BEGIN ===== 45550-12042010 00001SzFN0n1bPII7FnAxnt0DDOPJA ...
- Python学习——struct模块的pack、unpack示例
he struct module includes functions for converting between strings of bytes and native Python data t ...
- 发布项目MVC4-EF6.0出错
出错: The Entity Framework provider type 'System.Data.Entity.SqlServer.SqlProviderServices, EntityFram ...
- 触发器(trigger)的作用???
1.触发器,英文名trigger,可以简单的理解为: 就相当于是一个事件的触发装置,当满足了一定的事件触发条件后进行相应的操作 例如当复位set信号到来时,我们就让A<=B,这样一个系统就是一个 ...
- .gitignore无效,不能过滤某些文件
利用.gitignore过滤文件,如编译过程中的中间文件,等等,这些文件不需要被追踪管理. 现象: 在.gitignore添加file1文件,以过滤该文件,但是通过git status查看仍显示fil ...
- EntityFramework走马观花之CRUD(上)
对于任何一个ORM框架,CRUD都是其核心功能,可以这么说,CRUD功能实现得好坏,直接决定了此ORM框架的命运. CRUD是英文Create.Read.Update.Delete四个单词的缩写,对应 ...
- Netsharp快速入门(之1) 介绍及需求说明
作者:秋时 杨昶 时间:2014-02-15 转载须说明出处 第一章 快速入门介绍 Netsharp是一个企业基础业务管理平台,介绍Netsharp分三个系列,分别是: 1. N ...
- 浅谈自我对git的初步认识
本学期我们新增了一门课程,那就是软件工程,不知道为什么,感觉有种莫名的高大上.哈哈!难道是这个名称太抽象了吗?这个问题我感觉到后来肯定就明白了. 第一次博客,感觉好紧张哦,嘿嘿!老师让我们谈谈对git ...
- Poj 1222 EXTENDED LIGHTS OUT
题目大意:给你一个5*6的格子,每个格子中有灯(亮着1,暗着0),每次你可以把一个暗的点亮(或者亮的熄灭)然后它上下左右的灯也会跟着变化.最后让你把所有的灯熄灭,问你应该改变哪些灯. 首先我们可以发现 ...