P1707 刷题比赛
P1707 刷题比赛
题目背景
nodgd是一个喜欢写程序的同学,前不久洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题。于是发生了一系列有趣的事情,他就打算用这些事情来出题恶心大家……
题目描述
洛谷OJ当然算是好地方,nodgd同学打算和朋友分享一下。于是他就拉上了他的朋友Ciocio和Nicole两位同学一起刷题。喜欢比赛的他们当然不放过这样一次刷题比赛的机会!
在第1天nodgd,Coicoi,Nicole都只做了1道题。
在第2天nodgd,Coicoi,Nicole都只做了3道题。
他们都有着严格的刷题规则,并且会在每一天都很遵守规则的刷一定量的题。
(1)nodgd同学第k+2天刷题数量a[k+2]=p*a[k+1]+q*a[k]+b[k+1]+c[k+1]+r*k^2+t*k+1;
(2)Ciocio同学第k+2天刷题数量b[k+2]=u*b[k+1]+v*b[k]+a[k+1]+c[k+1]+w^k;
(3)Nicole同学第k+2天刷题数量c[k+2]=x*c[k+1]+y*c[k]+a[k+1]+b[k+1]+z^k+k+2;
(以上的字母p,q,r,t,u,v,w,x,y,z都是给定的常数,并保证是正整数)
于是他们开始了长时间的刷题比赛!一共进行了N天(4<=N<=10^16)
但是时间是可贵的,nodgd想快速知道第N天每个人的刷题数量。不过nodgd同学还有大量的数学竞赛题、物理竞赛题、英语竞赛题、美术竞赛题、体育竞赛题……要做,就拜托你来帮他算算了。
由于结果很大,输出结果mod K的值即可。
输入输出格式
输入格式:
第一行两个正整数N,K。(4<=N<=10^16,2<=K<=10^16)
第二行四个正整数p,q,r,t。
第三行三个正整数u,v,w。
第四行三个正整数x,y,z。
(保证p,q,r,t,u,v,w,x,y,z都是不超过100的正整数)
输出格式:
共三行,每行一个名字+一个空格+一个整数。依次是nodgd,Ciocio,Nicole和他们在第N天刷题数量mod K的值。
输入输出样例
4 10007
2 1 1 1
2 2 3
1 1 2
nodgd 74
Ciocio 80
Nicole 59
说明
矩阵乘法。
注意,中间相乘过程可能会比64位长整型的数据范围还要大。
看到数据范围很大,之后异想天开,以为一定会答案循环,再加上快速幂,最多也只是50分。
#include<cstdio>
#include<iostream>
#define ll long long
using namespace std;
const int N=2e5+;
ll n,mod;
ll a[N]={,,};
ll b[N]={,,};
ll c[N]={,,};
ll kpow(ll a,ll p){
ll ans=;
for(;p;p>>=,a=(a*a)%mod) if(p&) ans=(ans*a)%mod;
return ans;
}
int main(){
//freopen("sh.txt","r",stdin);
int p,q,r,t,u,v,w,x,y,z;ll ma(),mb(),mc();bool fa(),fb(),fc();
cin>>n>>mod;
cin>>p>>q>>r>>t>>u>>v>>w>>x>>y>>z;
if(mod==){printf("nodgd 0\nCiocio 0\nNicole 0\n");return ;}
if(n==){printf("nodgd 1\nCiocio 1\nNicole 1\n");return ;}
if(n==){printf("nodgd %d\nCiocio %d\nNicole %d\n",%mod,%mod,%mod);return ;}
for(ll i=;i<=n;i++){
a[i]=(p*a[i-]%mod+q*a[i-]%mod+b[i-]+c[i-]+r%mod*kpow((i-)%mod,)%mod+t*(i-)%mod+)%mod;
b[i]=(u*b[i-]%mod+v*b[i-]%mod+a[i-]+c[i-]+kpow(w%mod,(i-))%mod)%mod;
c[i]=(x*c[i-]%mod+y*c[i-]%mod+a[i-]+b[i-]+kpow(z%mod,(i-))%mod+i)%mod;
if(a[i]==a[]&&a[i-]==a[]){ma=i-;fa=;}
if(b[i]==b[]&&b[i-]==b[]){mb=i-;fb=;}
if(c[i]==c[]&&c[i-]==c[]){mc=i-;fc=;}
if(fa&&fb&&fc) break;
}
if(fa&&fb&&fc){
cout<<"nodgd "<<a[n%ma]<<endl;
cout<<"Ciocio "<<b[n%mb]<<endl;
cout<<"Nicole "<<c[n%mc]<<endl;
}
else{
cout<<"nodgd "<<a[n]<<endl;
cout<<"Ciocio "<<b[n]<<endl;
cout<<"Nicole "<<c[n]<<endl;
}
return ;
}
看到标签,“矩阵乘法”,去网上看了看矩阵乘法
附上AC代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
ll n,mod,p,q,r,t,u,v,w,x,y,z;
ll f[][],a[][];
ll slow_mul(ll a,ll b){
ll ans=;
while(b){
if(b&){
b--;ans+=a;ans%=mod;
}
a<<=;a%=mod;b>>=;
}
return ans;
}
void mul(ll a[][],ll b[][]){
ll c[][];memset(c,,sizeof(c));
for(int i=;i<=;i++)
for(int j=;j<=;j++)
for(int k=;k<=;k++)
c[i][j]=(c[i][j]+slow_mul(a[i][k],b[k][j]))%mod;
for(int i=;i<=;i++)
for(int j=;j<=;j++)
a[i][j]=c[i][j];
}
int main()
{
cin>>n>>mod>>p>>q>>r>>t>>u>>v>>w>>x>>y>>z;n-=;
f[][]=f[][]=f[][]=;f[][]=f[][]=f[][]=;
f[][]=f[][]=f[][]=;f[][]=w;f[][]=z;
a[][]=p;a[][]=q;a[][]=r;a[][]=t;a[][]=u;
a[][]=v;a[][]=x;a[][]=y;a[][]=a[][]=;
a[][]=w;a[][]=z;
a[][]=a[][]=a[][]=a[][]=a[][]=a[][]=;
a[][]=a[][]=a[][]=a[][]=a[][]=a[][]=;
a[][]=a[][]=a[][]=a[][]=a[][]=a[][]=;
while(n){
if(n&)mul(f,a);
mul(a,a);n>>=;
}
cout<<"nodgd"<<" "<<f[][]<<endl;
cout<<"Ciocio"<<" "<<f[][]<<endl;
cout<<"Nicole"<<" "<<f[][]<<endl;
return ;
}
P1707 刷题比赛的更多相关文章
- [洛谷P1707] 刷题比赛
洛谷题目连接:刷题比赛 题目背景 nodgd是一个喜欢写程序的同学,前不久洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题.于是发生了一系列有趣的事情,他就打算用这些事情来出题恶心大家-- ...
- luogu题解 P1707 【刷题比赛】矩阵加速递推
题目链接: https://www.luogu.org/problemnew/show/P1707 分析: 洛谷的一道原创题,对于练习矩阵加速递推非常不错. 首先我们看一下递推式: \(a[k+2]= ...
- 【洛谷 P1707】 刷题比赛 (矩阵加速)
题目连接 很久没写矩阵加速了,复习一下,没想到是一道小毒瘤题. 状态矩阵\(a[k],b[k],c[k],a[k+1],b[k+1],c[k+1],k,k^2,w^k,z^k,1\) 转移矩阵 0, ...
- [luogu1707] 刷题比赛 [矩阵快速幂]
题面: 传送门 思路: 一眼看上去是三个递推......好像还挺麻烦的 仔细观察一下,发现也就是一个线性递推,但是其中后面的常数项比较麻烦 观察一下,这里面有以下三个递推是比较麻烦的 第一个是$k^2 ...
- ubuntu下vim配置(刷题和比赛两套)
1. 平时刷题练习使用 "mswin.vim 插件提供windows下的编辑快捷键功能 source $VIMRUNTIME/mswin.vim behave mswin set nu se ...
- ife任务刷题总结(一)-css reset与清除浮动
本文同时发布于本人的个人网站www.yaoxiaowen.com 百度创办的前端技术学院,是一个面向大学生的前端技术学习平台.虽然只有大学生才有资格报名,提交代码进行比赛排名.但是这并不妨碍我们这些初 ...
- 【刷题记录】BZOJ-USACO
接下来要滚去bzoj刷usaco的题目辣=v=在博客记录一下刷题情况,以及存一存代码咯.加油! 1.[bzoj1597][Usaco2008 Mar]土地购买 #include<cstdio&g ...
- NOIp2018停课刷题记录
Preface 老叶说了高中停课但是初中不停的消息后我就为争取民主献出一份力量 其实就是和老师申请了下让我们HW的三个人听课结果真停了 那么还是珍惜这次机会好好提升下自己吧不然就\(AFO\)了 Li ...
- 【刷题】BZOJ 2407 探险
Description 探险家小T好高兴!X国要举办一次溶洞探险比赛,获奖者将得到丰厚奖品哦!小T虽然对奖品不感兴趣,但是这个大振名声的机会当然不能错过! 比赛即将开始,工作人员说明了这次比赛的规则: ...
随机推荐
- Spring优势
* 使用spring有什么好处? ◆Spring能有效地组织你的中间层对象,无论你是否选择使用了EJB.如果你仅仅使用了Struts或其他的包含了J2EE特有APIs的framework,你会发现S ...
- PHP 根据类名和方法名已面向对象的方式执行函数。
<?php echo 'testClass'; echo '<br><hr>'; $className = 'TestClass'; $methodName = 'c_o ...
- BZOJ 1014: [JSOI2008]火星人prefix Splay+二分
1014: [JSOI2008]火星人prefix 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1014 Description 火星人 ...
- Codeforces Round #180 (Div. 2) A. Snow Footprints 贪心
A. Snow Footprints 题目连接: http://www.codeforces.com/contest/298/problem/A Description There is a stra ...
- AES加密算法
代码是抄的,版权信息有 代码压缩包下载地址:http://pan.baidu.com/s/1jGEKH1c AES.h /////////////////////////////// // http: ...
- android标题栏(titlebar)显示进度条
在后台线程中执行各种操作(网络连接.大数据存储)的时候,我们希望让客户能看到后台有操作在进行,那么既能有效的提示用户,又不占用当前操作空间,最好的方法就是在标题栏有个进度条. [代码] [Java]代 ...
- python 列表函数(转)
list函数: 功能:将字符创转化为列表,例: 列表基本函数: 1.元素赋值,例: 注意:通过list[0]= 'hel',如果原来位置上有值,会覆盖掉原来的. 2.分片操作 1)显示序列,例: 注意 ...
- web开发下的各种下载方法
利用TransmitFile方法,解决Response.BinaryWrite下载超过400mb的文件时导致Aspnet_wp.exe进程回收而无法成功下载的问题. 代码如下: Response.Co ...
- vba用http发送xml所需技术
1.代理(invoke) CallByName 函数 •执行一个对象的方法,或者设置或返回一个对象的属性. •语法 •CallByName(object, procname, calltype,[ar ...
- cigarettes
描述 Tom has many cigarettes. We hypothesized that he has n cigarettes and smokes them one by one keep ...