思路:矩阵快速幂+中国剩余定理!!

查资料得到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的更多相关文章

  1. HDU 4767 Bell(矩阵+中国剩余定理)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4767 题意:给出n.求n有多少种划分集合的方式,即bell(n) 思路: #include <i ...

  2. 2013长春网赛1009 hdu 4767 Bell(矩阵快速幂+中国剩余定理)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4767 题意:求集合{1, 2, 3, ..., n}有多少种划分情况bell[n],最后结果bell[ ...

  3. HDU 4767——Bell

    昨天比赛被虐的这个题目. 今天听斌牛讲过他的思路后就A掉了. 题目的意思是要你求出bell数的第n项对95041567取模. 首先,95041567=31*37*41*43*47: 然后取模就是先分别 ...

  4. HDU 4767

    昨晚苦恼了一晚,因为即将大三了,必须要准备实习什么的事了.一般都会去公司实习吧,但是看看自己的简历,实在拿不出手,因为大一大二都在搞ACM(虽然真正搞的只有大二一年),但却没有什么成绩,又不愿意做项目 ...

  5. Bell(hdu4767+矩阵+中国剩余定理+bell数+Stirling数+欧几里德)

    Bell Time Limit:3000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status  ...

  6. Bell(矩阵快速幂+中国剩余定理)

    Bell Time Limit:3000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status  ...

  7. hdu 5445 Food Problem 多重背包

    Food Problem Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5 ...

  8. hdu 5445 多重背包

    Food Problem Time Limit: 3000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)To ...

  9. HDU 2512 一卡通大冒险(第二类斯特林数+贝尔数)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2512 题目大意:因为长期钻研算法, 无暇顾及个人问题,BUAA ACM/ICPC 训练小组的帅哥们大部 ...

随机推荐

  1. Android内存管理机制

    相信一步步走过来的Android从业者,每个人都会遇到OOM的情况.如何避免和防范OOM的出现,对于每一个程序员来说确实是一门必不可少的能力. 今天我们就谈谈在Android平台下内存的管理之道,开始 ...

  2. nodejs for centos配置

    mongodb http://www.cnblogs.com/zhoulf/archive/2013/01/31/2887439.html nodejs http://zhaohe162.blog.1 ...

  3. ExtJS MVC学习手记

    开始学习ExtJS的MVC了.这篇文章仅是用来做一个目录,为自己这个阶段的学习内容做个索引. 手记涉及的文章: EXTJS MVC结构(译自ExtJS4.0文档中的<MVC Architectu ...

  4. 最近对python颇有兴趣

    因为最近租的房子到期了,于是在豆瓣小组找房子,萌生利用python爬虫去抓取小组的房源信息. 最近2个小玩意准备做一下,mark 一下 1.豆瓣租房小组Python爬虫抓取 2.51job 职位抓取

  5. 在EDK里面添加ISE IP core的方法

    (1)在ISE下,使用core generator,可以得到xilinx的IP的*.v和*.ngc 文件,将这两个文件拷贝出来: (2)在EDK下使用“Create or Import Periphe ...

  6. Unity3D定制新建C#文件的头描述

    1. 修改模板内容如下: MAC:Unity.app/Contents/Resources/ScriptTemplates/81-C# Script-NewBehaviourScript.cs.txt ...

  7. 与电子钱包相关的APDU指令

    CLS:命令报文的类别字节,class byte(类别字节) of command message(命令报文) UranusPay ED/EP: UranusPay是HB公司开发的COS,而ED是电子 ...

  8. 我教女朋友学编程html系列(7)—Html无序列表、自定义列表、有序列表及常用例子

    昨天写的那篇文章<我教女朋友学编程Html系列(6)—Html常用表单控件>,基本上有1000人左右看了,那边文章是我站在前人的肩膀上修改来的,添加了截图和说明,合并了例子,使之更容易被初 ...

  9. 4、android xml中drawableTop(drawableBoottom、drawableLeft、drawableRight)在java代码中的动态配置

    做安卓开发的朋友都知道,我们在xml中可以通过这样来对button设置其上部或者(下.左.右)的图片资源: 那么如果需要动态配置图片呢?我们不得不使用java代码来进行操作: Drawable dra ...

  10. 关于Python中的yield

    关于Python中的yield   在介绍yield前有必要先说明下Python中的迭代器(iterator)和生成器(constructor). 一.迭代器(iterator) 在Python中,f ...