codeforces575A Fibonotci
题目大意:f[k]=f[k-1]*s[(n-1)%n]+f[(k-2)]*s[(k-2)%n];会修改某一位置的s值,但循环不变,求f[k];
矩阵快速幂裸题,由于有修改,所以需要线段树优化
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define maxn 50005
#define f(c,d) ((1<<(c))*(d))
struct node{
ll x[][];
}mt,mi,t,tt,x[][maxn];
int n,m,p;
ll k,s[maxn],ti;
pair<ll,ll>v[maxn];
node operator * (node a,node b){
node c=mt;
for(int i=;i<;++i)
for(int j=;j<;++j)
for(int k=;k<;++k)
c.x[i][j]=(c.x[i][j]+a.x[i][k]*b.x[k][j]%p)%p;
return c;
}
node operator ^ (node a,ll y){
if(y==)return mi;
node c=a;y--;
while(y){
if(y&)c=c*a;
y>>=;a=a*a;
}return c;
}
node ask(int a,int b,int c,int d){
if(f(c,d)==a&&f(c,d+)==b)return x[c][d];
c--;d=d<<|;
if(b<=f(c,d))return ask(a,b,c,d-);
if(a>=f(c,d))return ask(a,b,c,d);
return ask(a,f(c,d),c,d-)*ask(f(c,d),b,c,d);
}
node ask(int a,int b){
if(a==b)return mi;
return ask(a,b,,);
}
void to(ll a){
if(a/n-ti/n){
t=t*ask(ti%n,n);
t=t*(x[][]^(a/n-ti/n-));
t=t*ask(,a%n);
}else t=t*ask(ti%n,a%n);
ti=a;
}
int main(){
scanf("%I64d%d",&k,&p);
mi.x[][]=mi.x[][]=%p;
scanf("%d",&n);
for(int i=;i<n;++i)scanf("%I64d",&s[i]);
for(int i=;i<n;++i){
x[][i].x[][]=s[i]%p;
x[][i].x[][]=;
x[][i].x[][]=s[(i+)%n]%p;
}
for(int i=;i<;++i)
for(int j=;f(i,j)<n;++j){
x[i][j]=x[i-][j<<];
if(f(i-,(j<<|))<n)x[i][j]=x[i-][j<<]*x[i-][j<<|];
}
scanf("%d",&m);
for(int i=;i<m;++i)scanf("%I64d%I64d",&v[i].first,&v[i].second);
sort(v,v+m);
ti=;
t=mi;
for(int i=;i<m;++i){
if(v[i].first>k)break;
if(ti!=v[i].first){
to(v[i].first-);
tt.x[][]=s[ti%n]%p;
tt.x[][]=;
tt.x[][]=v[i].second%p;
t=t*tt;
ti++;
}
if(ti==k)break;
ti++;
tt.x[][]=v[i].second%p;
tt.x[][]=;
tt.x[][]=(v[i+].first==ti?v[i+].second:s[ti%n])%p;
t=t*tt;
}
to(k);
printf("%I64d\n",t.x[][]);
return ;
}
575A
codeforces575A Fibonotci的更多相关文章
- cf575A Fibonotci
Fibonotci sequence is an integer recursive sequence defined by the recurrence relation Fn = sn - 1·F ...
- Bubble Cup 8 finals A. Fibonotci (575A)
题意: 定义类循环序列为 长度无限,且除了有限个元素外,均满足s[i] ≡ s[i mod N] (i≥N). 现在有数列F,定义为 F[i] = s[i-2]*F[i-1] + s[i-1]*F[i ...
- CF575A Fibonotci [线段树+矩阵快速幂]
题意 \(s\{\}\) 是一个循环数列 循环节为 \(n\),你可以改掉 \(m\) 项,这 \(m\) 项独立,且不影响循环节 考虑线段树维护矩阵,单点修改最多m次,每次矩阵快速幂就完事了 // ...
- Codeforces 575A - Fibonotci
题面传送门 题意: 给出 \(s_0,s_1,s_2,\dots,s_{n-1}\),对于 \(i\geq n\),有 \(m\) 个 \(s_i\) 满足 \(s_i\neq s_{i\bmod n ...
- 「考试」联赛模拟36-39,noip晚间小测2-3
36.1 party(CF623D) 很是鸡贼的一道题 首先要明确一点,抓人是有策略,而不是随机的,可以认为等同于按一个给定的顺序猜人,那么这时猜中的概率就只是抓住这个人的概率了 对于每一次猜测,因为 ...
随机推荐
- DSP using MATLAB示例Example3.16
代码: b = [0.0181, 0.0543, 0.0543, 0.0181]; % filter coefficient array b a = [1.0000, -1.7600, 1.1829, ...
- Flume interceptor 使用注意事项
1. 在使用 Regex Filtering Interceptor的时候一个属性是excludeEvents 当它的值为true 的时候,过滤掉匹配到当前正则表达式的一行 当它的值为false的时候 ...
- mac 快捷键大全
1.control+space 可以使用 spotlight搜索,用于快速找到所需要的文件 2.我尝试使用android studio 提示的快捷键来进行写代码,发现自己按照它的提示操作没有成功,原因 ...
- BZOJ2159 : Crash 的文明世界
$x^k=\sum_{i=1}^k Stirling2(k,i)\times i!\times C(x,i)$ 设$f[i][j]=\sum_{k=1}^n C(dist(i,k),j)$. 则可以利 ...
- MySQL设置当前时间为默认值的方法
方法一.是用alert table语句: 复制代码代码如下: use test_db1; create table test_ta1( id mediumint(8) unsigned not nul ...
- Set集合对象比较两个元素的方法
Set集合对象比较两个元素的方法并不是根据“equals()”方法的返回值来比较.而是用“hashCode()”方法来进行判断.只要两个元素的“hashCode()”方法的返回值相同,就认为两个元素相 ...
- ACM cigarettes
cigarettes 时间限制:3000 ms | 内存限制:65535 KB 难度:2 描述 Tom has many cigarettes. We hypothesized that he ...
- 洛谷 P1967 货车运输 Label: 倍增LCA && 最小瓶颈路
题目描述 A 国有 n 座城市,编号从 1 到 n,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重.现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下,最多 ...
- [题解]扫雷Mine
// 此博文为迁移而来,写于2015年2月6日,不代表本人现在的观点与看法.原始地址:http://blog.sina.com.cn/s/blog_6022c4720102vrft.html 1088 ...
- virtual关键字的本质是什么?
MSDN上对virtual方法的解释:试着翻译如下 当一个方法声明包含virtual修饰符,这个方法就是虚方法.如果没有virtual修饰符,那么就不是虚方法. 非虚方法的实现是不变的:不管该方法是被 ...