HDU 4767——Bell
昨天比赛被虐的这个题目。
今天听斌牛讲过他的思路后就A掉了。
题目的意思是要你求出bell数的第n项对95041567取模。
首先,95041567=31*37*41*43*47;
然后取模就是先分别取模,然后就用中国剩余定理合并了。
现在的问题就是如何求出来B[n]对95041567分别取模的结果了哦。
不错,现在你缺少的就是一个公式——B[P^m+n]==(B[n]+B[n+1])%P——P为任一个质数(来自维基百科)。
这样的话我们就可以递推了哦。
从大的开始往小的递推,每次减去一个最大的P^m,知道推到一个n<=P,用记忆化<map>就A掉了。
代码如下:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <map>
#define N 95041567
#define maxn 2147483647
#define ll long long
using namespace std; llm[5]={31,37,41,43,47},a[5],n,t;
llf[5][50][50];
map<ll,ll>ss; void function()
{
for (lli=0; i<5; i++)
{
f[i][0][0]=1;
f[i][1][1]=1;
for (llj=2; j<=m[i]; j++)
{
f[i][j][1]=f[i][j-1][j-1];
for (llk=2; k<=j; k++)
f[i][j][k]=(f[i][j][k-1]+f[i][j-1][k-1])%m[i];
}
}
} llget(lltot,llx)
{
if (tot<=m[x]) return f[x][tot][tot];
if (ss[tot]!=0) return ss[tot];
llM=1,cur=m[x];
while (cur*m[x]<=tot) M++,cur*=m[x];
ss[tot]=(M*get(tot-cur,x)+get(tot-cur+1,x))%m[x];
return ss[tot];
} void exgcd(llA,llB,ll& x,ll& y)
{
if (!B) { x=1,y=0; }
else { exgcd(B,A%B,y,x); y-=A/B*x; }
} llchina()
{
lld,x=0,y;
for (lli=0; i<5; i++)
{
llw=N/m[i];
exgcd(m[i],w,d,y);
x=(x+y*w*a[i])%N;
}
return (x+N)%N;
} int main()
{
function();
cin>>t;
while (t--)
{
cin>>n;
for (lli=0; i<5; i++)
{
ss.clear();
a[i]=get(n,i);
}
cout<<china()<<"\n";
}
return 0;
}
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
思路:矩阵快速幂+中国剩余定理!! 查资料得到2个公式: 1) B[n+p] = B[n] + B[n+1] mod p ; 2) B[p^m+n] = ...
- 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 训练小组的帅哥们大部 ...
随机推荐
- 20155310马英林 实验2 Windows口令破解
实 验 报 告 实验名称: 实验二 口令破解 姓名:马英林 学号: 20155310 班级: 1553 日期: 2017.10.24 一. 实验环境 •系统环境:Windows •网络环境:交换网络结 ...
- echarts 拐点添加图片
series : [ { name:'搜索引擎', type:'line', symbol:'emptyCircle', symbolSize: 5, itemStyle: { normal: { l ...
- 同步备份工具之 rsync
1.常用同步方法 SCP. NFS. SFTP. http. samba. rsync. drbd(基于文件系统同步,效率高) 2.rsync 介绍 rsync,英文全称是 remote synchr ...
- Arduino 101/Genuino101使用-第2篇
1. Arduino 101编程只是在ARC的核心上进行,其具体架构为ARCv2EM.. 2. 而Quark核心,从目前可知的信息来看,其应该运行着名为Zephyr的RTOS 3.101并没有EEPR ...
- angular之$watch() $watchGroup()和$watchCollection()
$watch $watch主要是用来监听一个对象,在对象发生变化时触发某个事件. 用法: $scope.$watch(watchFn,watchAction, deepWatch) 接下来讲一下这几个 ...
- scala : 类型与类
scala类型系统:1) 类型与类 在Java里,一直到jdk1.5之前,我们说一个对象的类型(type),都与它的class是一一映射的,通过获取它们的class对象,比如 String.class ...
- 基于ejabberd实现各个客户端消息同步
先上图再说(左侧是web端,右侧是ios端) 要实现上面的功能,如果所有设备都在线的话,那么carboncopy(xmpp xep-0280协议)这个模块是可以实现接收到的消 ...
- XAF-物料管理信息工作日志
前段时间已经开始了第一阶段验收了,客户方并未把重点放在业务流程上面,一直在调整一些界面问题.有点小纠结. 今天要调一下菜单位置. 没修改时,是这样的: 到了列表界面,会多一个全文检索出来. 后来,客户 ...
- 前端--javaScript之简单介绍
一.javaScript(以下简称js)的历史 1992年Nombas开发出C-minus-minus(C--)的嵌入式脚本语言(最初绑定在CEnvi软件中).后将其改名ScriptEase.(客户端 ...
- Phaser游戏框架与HTML Dom元素之间的通信交互
本想按照PHASER的HTML Dom元素官方实例:http://labs.phaser.io/index.html?dir=game%20objects/dom%20element/&q= ...