[noi2002]M号机器人
3030年,Macsy正在火星部署一批机器人。
第1秒,他把机器人1号运到了火星,机器人1号可以制造其他的机器人。
第2秒,机器人1号造出了第一个机器人——机器人2号。
第3秒,机器人1号造出了另一个机器人——机器人3号。
之后每一秒,机器人1号都可以造出一个新的机器人。第m秒造出的机器人编号为m。我们可以称它为机器人m号,或者m号机器人。
机器人造出来后,马上开始工作。m号机器人,每m秒会休息一次。比如3号机器人,会在第6,9,12,……秒休息,而其它时间都在工作。
机器人休息时,它的记忆将会被移植到当时出生的机器人的脑中。比如6号机器人出生时,2,3号机器人正在休息,因此,6号机器人会收到第2,3号机器人的记忆副本。我们称第2,3号机器人是6号机器人的老师。
如果两个机器人没有师徒关系,且没有共同的老师,则称这两个机器人的知识是互相独立的。注意:1号机器人与其他所有机器人的知识独立(因为只有1号才会造机器人),它也不是任何机器人的老师。
一个机器人的独立数,是指所有编号比它小且与它知识互相独立的机器人的个数。比如1号机器人的独立数为0,2号机器人的独立数为1(1号机器人与它知识互相独立),6号机器人的独立数为2(1,5号机器人与它知识互相独立,2,3号机器人都是它的老师,而4号机器人与它有共同的老师——2号机器人)。
新造出来的机器人有3种不同的职业。对于编号为m的机器人,如果能把m分解成偶数个不同奇素数的积,则它是政客,例如编号15;否则,如果m本身就是奇素数或者能把m分解成奇数个不同奇素数的积,则它是军人,例如编号 3, 编号165。其它编号的机器人都是学者,例如编号2, 编号6, 编号9。
第m秒诞生的机器人m号,想知道它和它的老师中,所有政客的独立数之和,所有军人的独立数之和,以及所有学者的独立数之和。可机器人m号忙于工作没时间计算,你能够帮助它吗?
为了方便你的计算,Macsy已经帮你做了m的素因子分解。为了输出方便,只要求输出总和除以10000的余数。
可以看出独立数就是欧拉函数值;
设f[i][j]表示前i个约数中选j个约数的欧拉函数值;
由于欧拉函数的是积性函数;
f[i][j]=f[i-1][j]+f[i-1][j-1]*(p[i]-1);相当于f[i][j]既可以由不选i得到,又可以从一定选i得到;
然后j%2=1的f[k][j]加起来得到了军人的,j%2==0的f[k][j]加起来得到了政客的;
欧拉函数有一个性质,m的约数的欧拉函数和是m;
然后m-ans1-ans2-1,得到了学者的;
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cstdlib>
#include<ctime>
#include<vector>
#include<algorithm>
#include<queue>
#include<map>
using namespace std;
#define LL long long
const int mod=;
int k;
int c[][],f[];
int mi(int a,int b){
int ans=;
while(b){
if(b%)ans=(ans*a)%mod;
b/=;
a=(a*a)%mod;
}
return ans;
}
void init(){
scanf("%d",&k);
for(int i=;i<=k;i++)scanf("%d%d",&c[i][],&c[i][]);
}
void work(){
int ans1=,ans2=,ans=,g;
if(c[][]==)g=;
else g=;
f[]=;
for(int i=g;i<=k;i++)
for(int j=i-g+;j>=;j--)
f[j]=(f[j]+f[j-]*(c[i][]-))%mod;
for(int i=;i<=k-g+;i++){
if(i%)ans1=(ans1+f[i])%mod;
else ans2=(ans2+f[i])%mod;
}
for(int i=;i<=k;i++)ans=(ans*mi(c[i][],c[i][]))%mod;
ans=(ans+-ans1-ans2-)%mod;
printf("%d\n%d\n%d\n",ans2,ans1,ans);
return;
}
int main(){
freopen("1.in","r",stdin);
freopen("1.out","w",stdout);
init();
work();
return ;
}
[noi2002]M号机器人的更多相关文章
- JZYZOJ1378 [noi2002]M号机器人  欧拉函数
		http://172.20.6.3/Problem_Show.asp?id=1378日常懒得看题目怪不得语文差,要好好读题目了,欧拉函数大概是数论里最友好的了,不用解方程不用转换过来转换过去只需要简单 ... 
- 【机器人M号】题解
		题目 题目描述 3030年,Macsy正在火星部署一批机器人. 第1秒,他把机器人1号运到了火星,机器人1号可以制造其他的机器人. 第2秒,机器人1号造出了第一个机器人--机器人2号. 第3秒,机器人 ... 
- BZOJ 1408: [Noi2002]Robot
		1408: [Noi2002]Robot Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 510 Solved: 344[Submit][Status][ ... 
- 【BZOJ1408】[Noi2002]Robot DP+数学
		[BZOJ1408][Noi2002]Robot Description Input Output Sample Input 3 2 1 3 2 5 1 Sample Output 8 6 75 HI ... 
- 【BZOJ】【3205】【APIO2013】机器人robot
		斯坦纳树 好神啊……Orz zyf && PoPoQQQ 为啥跟斯坦纳树扯上关系了?我想是因为每个点(robot)都沿着树边汇到根的时候就全部合起来了吧= =这个好像和裸的斯坦纳树不太 ... 
- weiphp 微信公众号用程序来设置指定内容消息回复业务逻辑操作
		微信公众号机器人回复设置 在公众号插件里面的Robot- Model- weixinAddonModel.php里面的 reply设置 reply($dataArr,$keywordArr) 解析方法 ... 
- BZOJ_1408_[Noi2002]Robot_数学
		Description Input Output Sample Input 3 2 1 3 2 5 1 Sample Output 8 6 75 HINT 90号机器人有10个老师,加上它自己共11个 ... 
- [APIO2013]机器人(斯坦纳树)
		题目描述 VRI(Voltron 机器人学会)的工程师建造了 n 个机器人.任意两个兼容的机 器人站在同一个格子时可以合并为一个复合机器人. 我们把机器人用 1 至 n 编号(n ≤ 9).如果两个机 ... 
- hihocoder #1170 机器人 && 编程之美2015复赛
		题意: 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描写叙述 小冰的N个机器人兄弟排成一列,每一个机器人有一个颜色. 如今小冰想让同一颜色的机器人聚在一起.即随意两个同颜色的 ... 
随机推荐
- Pollard_rho定理 大数的因数个数  这个板子超级快
			https://nanti.jisuanke.com/t/A1413 AC代码 #include <cstdio> #include <cstring> #include &l ... 
- java布局(每个名字都是有意义的)
			一.FlowLayout 1.流水布局:从左至右,排满换行 2.构造函数有三种: (1)FlowLayout() (2)FlowLayout(align) (3)FlowLayout(align, h ... 
- Java集合——Collections工具类
			Java集合——Collections工具类 摘要:本文主要学习了Collections工具类的常用方法. 概述 Collections工具类主要用来操作集合类,比如List和Set. 常用操作 排序 ... 
- SqlServer 并发事务:死锁跟踪(三)6种跟踪死锁的方法总结  大神
			http://blog.csdn.net/kk185800961/article/details/42504857 
- Linux文件内容查阅
			直接查阅一个文件的内容:cat/tac/nl命令 cat (concatenate) # cat [-AbEnTv] 选项与參数: -A :相当於 -vET 的整合选项.可列出一些特殊字符而不是空白 ... 
- 醒醒吧少年,只用Cucumber不能帮助你BDD
			转载:http://insights.thoughtworkers.org/bdd/ 引言 在Ruby社区中,测试和BDD一直是被热议的话题,不管是单元测试.集成测试还是功能测试,你总能找到能帮助你的 ... 
- NYOJ 353 3D dungeon 【bfs】
			题意:给你一个高L长R宽C的图形.每个坐标都能够视为一个方格.你一次能够向上.下.左,右,前,后任一方向移动一个方格, 可是不能向有#标记的方格移动. 问:从S出发能不能到达E,假设能请输出最少的移动 ... 
- vue2.0 + vux (六)NewsList 资讯页  及  NewsDetail 资讯详情页
			设置代理,避免出现跨域问题 /*设置代理,避免出现跨域问题*/ proxyTable: { '/api':{ target: 'https://www.oschina.net/action/apiv2 ... 
- Android——通过Intent传递一些二进制数据的方法有哪些
			1.方法 (1)使用Serializable接口实现序列化.利用Bundle.putSerializable(Key, Object);这里objec对象需要实现serializable接口. (2) ... 
- STL中各容器之函数总结
			一.序列和关联非共同拥有函数 全部标准库共同拥有函数 (构造,相关属性,迭代器,插入与删除,比較.swap) 当中operator>,operator>=,operator<,op ... 
