2017 [六省联考] T2 相逢是问候
4869: [Shoi2017]相逢是问候
Time Limit: 40 Sec Memory Limit: 512 MB
Submit: 1205 Solved: 409
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
1 2 3 4
0 1 4
1 2 4
0 1 4
1 1 3
Sample Output
3
HINT
鸣谢多名网友提供正确数据,已重测!
Source
#include<bits/stdc++.h>
#define ll long long
#define maxn 50005
using namespace std;
int P[30],n,m,a[maxn];
int f[maxn],len,C,opt,TP;
int le,ri,tim[maxn],val[maxn];
set<int> s;
//set<int> ::iterator it; inline int add(int x,int y,const int ha){
x+=y;
return x>=ha?x-ha:x;
} inline int mod(int x,int y,const int ha){
ll P=x*(ll)y;
return P>=ha?P%ha+ha:P;
} inline int phi(int x){
int y=1;
for(int i=2;i*(ll)i<=x;i++) if(!(x%i)){
y*=(i-1),x/=i;
while(!(x%i)) x/=i,y*=i;
if(x==1) break;
} if(x!=1) return y*(x-1);
else return y;
} inline void update(int x,int y){
for(;x<=n;x+=x&-x) f[x]=add(f[x],y,P[0]);
} inline int query(int x){
int an=0;
for(;x;x-=x&-x) an=add(an,f[x],P[0]);
return an;
} inline int ksm(int x,int y,const int ha){
int an=1;
for(;y;y>>=1,x=mod(x,x,ha)) if(y&1) an=mod(an,x,ha);
return an;
} /*
int get(int sit,int pos){
if(sit==TP) return a[pos]>=P[sit]?a[pos]%P[sit]+P[sit]:a[pos];
else return ksm(C,get(sit+1,pos),P[sit]);
}
*/ inline void TOL(){
int now=*s.lower_bound(le);
for(;now<=ri;now=*s.upper_bound(now)){
update(now,P[0]-val[now]);
tim[now]++,TP=tim[now]; if(tim[now]>len) val[now]=1;
else val[now]=(a[now]>=P[TP]?a[now]%P[TP]+P[TP]:a[now]);
for(int i=TP-1;i>=0;i--){
val[now]=ksm(C,val[now],P[i]);
}
val[now]%=P[0]; update(now,val[now]); if(tim[now]==len+1) s.erase(now);
}
} int main(){
// freopen("9.in","r",stdin);
// freopen("9.out","w",stdout); scanf("%d%d%d%d",&n,&m,P,&C);
for(len=1;;len++){
P[len]=phi(P[len-1]);
if(P[len]==1) break;
}
s.insert(0),s.insert(n+1);
for(int i=1;i<=n;i++){
scanf("%d",a+i);
update(i,a[i]);
s.insert(i);
val[i]=a[i];
} while(m--){
scanf("%d%d%d",&opt,&le,&ri);
if(opt) printf("%d\n",add(query(ri),P[0]-query(le-1),P[0]));
else TOL();
} return 0;
}
2017 [六省联考] T2 相逢是问候的更多相关文章
- 2017 [六省联考] T5 分手是祝愿
4872: [Shoi2017]分手是祝愿 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 458 Solved: 299[Submit][Statu ...
- 2017 [六省联考] T1 期末考试
4868: [Shoi2017]期末考试 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 842 Solved: 385[Submit][Status ...
- 2017 [六省联考] T6 寿司餐厅
4873: [Shoi2017]寿司餐厅 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 450 Solved: 316[Submit][Status ...
- 洛谷 P3747 [六省联考2017]相逢是问候 解题报告
P3747 [六省联考2017]相逢是问候 题目描述 \(\text {Informatik verbindet dich und mich.}\) 信息将你我连结. \(B\) 君希望以维护一个长度 ...
- [BZOJ4869][六省联考2017]相逢是问候(线段树+扩展欧拉定理)
4869: [Shoi2017]相逢是问候 Time Limit: 40 Sec Memory Limit: 512 MBSubmit: 1313 Solved: 471[Submit][Stat ...
- 六省联考2017 Day1
目录 2018.3.18 Test T1 BZOJ.4868.[六省联考2017]期末考试 T2 T3 BZOJ.4870.[六省联考2017]组合数问题(DP 矩阵快速幂) 总结 考试代码 T1 T ...
- 六省联考2017 Day2
目录 2018.3.27 Test 总结 T1 T2 T3 BZOJ.4873.[六省联考2017]寿司餐厅(最小割ISAP 最大权闭合子图) 考试代码 T1 T2 T3 2018.3.27 Test ...
- [luogu] P3745 [六省联考2017]期末考试 (贪心)
P3745 [六省联考2017]期末考试 题目描述 有 \(n\) 位同学,每位同学都参加了全部的 \(m\) 门课程的期末考试,都在焦急的等待成绩的公布. 第 \(i\) 位同学希望在第 \(t_i ...
- 【BZOJ4873】[六省联考2017]寿司餐厅(网络流)
[BZOJ4873][六省联考2017]寿司餐厅(网络流) 题面 BZOJ 洛谷 题解 很有意思的题目 首先看到答案的计算方法,就很明显的感觉到是一个最大权闭合子图. 然后只需要考虑怎么构图就行了. ...
随机推荐
- LeetCode(225) Implement Stack using Queues
题目 Implement the following operations of a stack using queues. push(x) – Push element x onto stack. ...
- git push后是空目录,且提示modified content, untracked content
最近往自己的github传代码时,每一步都正常,但最后push上去之后是空目录,且在本地执行git status时提示: 后来发现是由于push的工程下本来就有个.git目录,所以才导致push上去的 ...
- iphone使用keychain来存取用户名和密码
1.在arc下系统提示使用__bridge http://www.cnblogs.com/zzltjnh/p/3885012.html 参考文档:http://blog.csdn.net/jerr ...
- 以http server为例简要分析netty3实现
概要 最近看了点netty3实现.从webbit项目作为口子.webbit项目是一个基于netty3做的http与websocket server.后面还会继续看下netty4,netty4有很多改进 ...
- [python工具][1]sublime安装与配置
http://www.cnblogs.com/wind128/p/4409422.html 1 官网下载版本 http://www.sublimetext.com/3 选择 Windows - al ...
- JAVA调用oracle存储过程实例
1.创建添加存储过程 CREATEORREPLACEPROCEDURE stu_proc(v_id INNUMBER, v_name INVARCHAR2, v_age INNUMBER) AS BE ...
- curl保存图片
$url = 'http://p1.qhimg.com/t013dfc89f8a039122c.jpg?size=690x460'; function http_get_data($url) { $c ...
- Z-Score数据标准化处理(python代码)
#/usr/bin/python def Z_Score(data): lenth = len(data) total = sum(data) ave = float(total)/lenth tem ...
- 给shell添加颜色
编辑/etc/baserc 添加 TERM=xterm-color; export TERM alias ls='ls -G' alias ll='ls -lG' 给vim添加颜色 编辑/usr/sh ...
- kb-01-d<poj3279>--深搜变种,二进制优化;
poj--3279 题意: 给n*m的矩阵,0 1组成,每次翻转一个格子可以将上下左右的五个节点翻转,求,把所有的格子翻转成0:输出每个个字的翻转次数:最少字数: 做法: 从上到下,第一行翻转的情况确 ...