P1707 刷题比赛

    • 10通过
    • 38提交
  • 题目提供者nodgd
  • 标签倍增递推矩阵洛谷原创
  • 难度提高+/省选-

提交该题 讨论 题解 记录

最新讨论

题目背景

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的值。

输入输出样例

输入样例#1:

4 10007
2 1 1 1
2 2 3
1 1 2
输出样例#1:

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 刷题比赛的更多相关文章

  1. [洛谷P1707] 刷题比赛

    洛谷题目连接:刷题比赛 题目背景 nodgd是一个喜欢写程序的同学,前不久洛谷OJ横空出世,nodgd同学当然第一时间来到洛谷OJ刷题.于是发生了一系列有趣的事情,他就打算用这些事情来出题恶心大家-- ...

  2. luogu题解 P1707 【刷题比赛】矩阵加速递推

    题目链接: https://www.luogu.org/problemnew/show/P1707 分析: 洛谷的一道原创题,对于练习矩阵加速递推非常不错. 首先我们看一下递推式: \(a[k+2]= ...

  3. 【洛谷 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, ...

  4. [luogu1707] 刷题比赛 [矩阵快速幂]

    题面: 传送门 思路: 一眼看上去是三个递推......好像还挺麻烦的 仔细观察一下,发现也就是一个线性递推,但是其中后面的常数项比较麻烦 观察一下,这里面有以下三个递推是比较麻烦的 第一个是$k^2 ...

  5. ubuntu下vim配置(刷题和比赛两套)

    1. 平时刷题练习使用 "mswin.vim 插件提供windows下的编辑快捷键功能 source $VIMRUNTIME/mswin.vim behave mswin set nu se ...

  6. ife任务刷题总结(一)-css reset与清除浮动

    本文同时发布于本人的个人网站www.yaoxiaowen.com 百度创办的前端技术学院,是一个面向大学生的前端技术学习平台.虽然只有大学生才有资格报名,提交代码进行比赛排名.但是这并不妨碍我们这些初 ...

  7. 【刷题记录】BZOJ-USACO

    接下来要滚去bzoj刷usaco的题目辣=v=在博客记录一下刷题情况,以及存一存代码咯.加油! 1.[bzoj1597][Usaco2008 Mar]土地购买 #include<cstdio&g ...

  8. NOIp2018停课刷题记录

    Preface 老叶说了高中停课但是初中不停的消息后我就为争取民主献出一份力量 其实就是和老师申请了下让我们HW的三个人听课结果真停了 那么还是珍惜这次机会好好提升下自己吧不然就\(AFO\)了 Li ...

  9. 【刷题】BZOJ 2407 探险

    Description 探险家小T好高兴!X国要举办一次溶洞探险比赛,获奖者将得到丰厚奖品哦!小T虽然对奖品不感兴趣,但是这个大振名声的机会当然不能错过! 比赛即将开始,工作人员说明了这次比赛的规则: ...

随机推荐

  1. ASP.NET|跳转(redirect)到其它站点,提示:当前线程终止。

    在XAF中,如果使用HttpContext.Response.Redirect()进行跳转,会出现”当前线程终止“的报错,跳转失败. 这时候,应该改用WebApplication.Redirect() ...

  2. Javascript(JS)对Cookie的读取、删除、写入操作帮助方法

    var CookieUtils = { get: function (name) { var cookieName = encodeURIComponent(name) + '=', cookieSt ...

  3. JS函数的定义与调用方法

    JS函数调用的四种方法:方法调用模式,函数调用模式,构造器调用模式,apply,call调用模式 1.方法调用模式:先定义一个对象,然后在对象的属性中定义方法,通过myobject.property来 ...

  4. Qtwebkit flashplayer插件问题

      复制npswf32.dll 到 C:\WINDOWS\system32\Macromed\Flash\ 代码加入: //! [1] QNetworkProxyFactory::setUseSyst ...

  5. Codeforces Round #180 (Div. 2) B. Sail 贪心

    B. Sail 题目连接: http://www.codeforces.com/contest/298/problem/B Description The polar bears are going ...

  6. FindMe

    https://github.com/hongdong/FindMe_Android https://github.com/hongdong/FindMe_Server https://github. ...

  7. 【JavaScript】JS中没有代码块的概念

    <script> var m = "roboce"; if(m === "roboce"){ var k = "haha"; } ...

  8. python 列表函数(转)

    list函数: 功能:将字符创转化为列表,例: 列表基本函数: 1.元素赋值,例: 注意:通过list[0]= 'hel',如果原来位置上有值,会覆盖掉原来的. 2.分片操作 1)显示序列,例: 注意 ...

  9. error C2440:“类型转换":无法从“void (__thiscall Play1::* )(int *)”转换为“cocos2d::SEL_CallFucN

    转自:http://zhidao.baidu.com/link?url=VfSSkA0xfTVwNKaKh4tqW_sXlcsK-Rb16nEtQw5zaq5_306lnwJN3Kdb-rFp-r4L ...

  10. lucene合并测试的总结

    1 查询的总时间等于每个segment查询时间的总和 2 合并的步骤     (1)做flush操作的先生成一个新的segment     (2)检查在新segment之前已经存在的segment的数 ...