洛谷P3747 [六省联考2017]相逢是问候
扩展欧拉定理。
线段树维护,已经全改到底了的节点就不管,不然暴力修改下去。
//Achen
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<vector>
#include<cstdio>
#include<queue>
#include<cmath>
const int N=+;
#define For(i,a,b) for(int i=(a);i<=(b);i++)
#define Rep(i,a,b) for(int i=(a);i>=(b);i--)
typedef long long LL;
using namespace std;
LL n,m,p,pp,c,tp,cnt,phi[],pr[][N],pr2[][N],mini[]; template<typename T>void read(T &x) {
char ch=getchar(); x=; T f=;
while(ch!='-'&&(ch<''||ch>'')) ch=getchar();
if(ch=='-') f=-,ch=getchar();
for(;ch>=''&&ch<='';ch=getchar()) x=x*+ch-''; x*=f;
} LL a[N],sg[N<<],tot[N<<]; int get_phi(int x) {
int up=sqrt(x),rs=x;
For(i,,up) {
if(!(x%i)) {
rs=rs-rs/i;
while(!(x%i)) x/=i;
}
}
if(x!=) rs=rs-rs/x;
return rs;
} LL get(int i,int a) { //c^a%phi[i]
return pr2[i][a/pp]*pr[i][a%pp]%phi[i];
} #define lc x<<1
#define rc x<<1|1
#define mid ((l+r)>>1)
void build(int x,int l,int r) {
if(l==r) { sg[x]=a[l]; return; }
build(lc,l,mid); build(rc,mid+,r);
sg[x]=(sg[lc]+sg[rc])%p;
tot[x]=min(tot[lc],tot[rc]);
} int lz[N<<];
void down(int x,int l_len,int r_len) {
if(!lz[x]) return;
if(l_len) { sg[lc]=l_len*c%p; tot[lc]=cnt; lz[lc]=; }
if(r_len) { sg[rc]=r_len*c%p; tot[rc]=cnt; lz[rc]=; }
lz[x]=;
} void update(int x,int l,int r,int ql,int qr) {
if(tot[x]>=cnt) return;
if(l>=ql&&r<=qr&&l==r) {
tot[x]++;
sg[x]=a[l]>=phi[tot[x]+]?a[l]%phi[tot[x]+]+phi[tot[x]+]:a[l];
Rep(i,tot[x],) {
int now=sg[x]>=mini[i];
sg[x]=get(i,sg[x]);
if(now&&i!=) sg[x]+=phi[i];
}
return ;
}
if(ql<=mid) update(lc,l,mid,ql,qr);
if(qr>mid) update(rc,mid+,r,ql,qr);
sg[x]=(sg[lc]+sg[rc])%p;
tot[x]=min(tot[lc],tot[rc]);
} LL qry(int x,int l,int r,int ql,int qr) {
if(l>=ql&&r<=qr) return sg[x];
down(x,mid-l+,r-mid);
if(qr<=mid) return qry(lc,l,mid,ql,qr);
if(ql>mid) return qry(rc,mid+,r,ql,qr);
return (qry(lc,l,mid,ql,qr)+qry(rc,mid+,r,ql,qr))%p;
} //#define DEBUG
int main() {
#ifdef DEBUG
freopen("bzoj4869相逢是问候.in","r",stdin);
freopen("bzoj4869相逢是问候.out","w",stdout);
#endif
read(n); read(m); read(p); read(c);
For(i,,n) read(a[i]);
build(,,n);
tp=p; phi[cnt=]=tp;
while(tp!=) {
phi[++cnt]=get_phi(tp);
tp=phi[cnt];
} phi[++cnt]=; phi[cnt+]=;
pp=1e4;
For(i,,cnt) {
tp=; int tc=;
if(c!=) {
for(;;) {
tp*=c; tc++;
if(tp>=phi[i]) {
mini[i]=tc;
break;
}
}
} else mini[i]=1e8;
pr[i][]=pr2[i][]=;
For(j,,pp)
pr[i][j]=pr[i][j-]*c%phi[i];
For(j,,pp)
pr2[i][j]=pr2[i][j-]*pr[i][pp]%phi[i];
} if(c!=) { mini[cnt]=; mini[cnt-]=; }
while(m--) {
int o,l,r;
read(o); read(l); read(r);
if(!o) update(,,n,l,r);
else printf("%lld\n",qry(,,n,l,r)%p);
}
return ;
}
洛谷P3747 [六省联考2017]相逢是问候的更多相关文章
- 洛谷 P3747 [六省联考2017]相逢是问候 解题报告
P3747 [六省联考2017]相逢是问候 题目描述 \(\text {Informatik verbindet dich und mich.}\) 信息将你我连结. \(B\) 君希望以维护一个长度 ...
- P3747 [六省联考2017]相逢是问候
题意 如果对一个数操作\(k\)次,那么这个数会变成\(c^{c^{...^{a_i}}}\),其中\(c\)有\(k\)个. 根据P4139 上帝与集合的正确用法这道题,我们可以知道一个数不断变为自 ...
- [BZOJ4869][六省联考2017]相逢是问候(线段树+扩展欧拉定理)
4869: [Shoi2017]相逢是问候 Time Limit: 40 Sec Memory Limit: 512 MBSubmit: 1313 Solved: 471[Submit][Stat ...
- 洛谷P3750 [六省联考2017]分手是祝愿(期望dp)
传送门 嗯……概率期望这东西太神了…… 先考虑一下最佳方案,肯定是从大到小亮的就灭(这个仔细想一想应该就能发现) 那么直接一遍枚举就能$O(nlogn)$把这个东西给搞出来 然后考虑期望dp,设$f[ ...
- 洛谷P3746 [六省联考2017]组合数问题
题目描述 组合数 C_n^mCnm 表示的是从 n 个互不相同的物品中选出 m 个物品的方案数.举个例子,从 (1;2;3) 三个物品中选择两个物品可以有 (1;2);(1;3);(2;3) 这三种 ...
- 洛谷 P3745 [六省联考2017]期末考试
题目描述 有 nnn 位同学,每位同学都参加了全部的 mmm 门课程的期末考试,都在焦急的等待成绩的公布. 第 iii 位同学希望在第 tit_iti 天或之前得知所有课程的成绩.如果在第 tit_ ...
- 洛谷P3749 [六省联考2017]寿司餐厅
传送门 题解 这几道都是上周llj讲的题,题解也写得十分好了,所以直接贴了几个链接和代码. //Achen #include<algorithm> #include<iostream ...
- 洛谷P3745 [六省联考2017]期末考试
传送门 题解 //Achen #include<algorithm> #include<iostream> #include<cstring> #include&l ...
- 洛谷 P3750 [六省联考2017]分手是祝愿
传送门 题解 //Achen #include<algorithm> #include<iostream> #include<cstring> #include&l ...
随机推荐
- 思维题+栈的应用——cf1092D有意思
第一例很简单,把两个差为偶数的列不断合并即可 这种不需要撤销的合并相连数直接用栈来做 /* 如果相邻两列高度差为偶数 那么可以直接消去 */ #include<bits/stdc++.h> ...
- python模块operator对排序的辅助功能
一.介绍 该operator模块导出一组与Python的内部运算符相对应的高效函数.例如,等同于表达式.函数名称是用于特殊类方法的函数名称; 为方便起见,还提供了没有前导和尾随的变体.operator ...
- NPM 使用介绍(包管理工具,解决NodeJS代码部署上的很多问题)
引用地址:http://www.runoob.com/nodejs/nodejs-npm.html NPM 使用介绍 NPM是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问 ...
- Storm 测试
本文将学习如何使用java创建Storm拓扑 Storm集群的组件 Storm集群类似于Hadoop集群,只不过 Hadoop 上运行"MapReduce jobs", Storm ...
- day 72 Django基础七之Ajax
Django基础七之Ajax 本节目录 一 Ajax简介 二 Ajax使用 三 Ajax请求设置csrf_token 四 关于json 五 补充一个SweetAlert插件(了解) 六 同源策略与 ...
- 面试系列16 dubbo负载均衡策略和集群容错策略都有哪些?动态代理策略呢
(1)dubbo负载均衡策略 1)random loadbalance 默认情况下,dubbo是random load balance随机调用实现负载均衡,可以对provider不同实例设置不同的权重 ...
- Dubbo + Kryo 实现高速序列化
Dubbo 中的序列化 Dubbo RPC 是 Dubbo 体系中最核心的一种高性能.高吞吐量的远程调用方式,可以称之为多路复用的 TCP 长连接调用: 长连接:避免了每次调用新建 TCP 连接,提高 ...
- [Ceoi2016|BZOJ4936] Match
哈希+分治+stack 题目: 给你一个由小写字母组成的字符串s,要你构造一个字典序最小的(认为左括号的字典序比右括号小)合法的括号 序列与这个字符串匹配,字符串和括号序列匹配定义为:首先长度必须相等 ...
- android 遍历控件
做个笔记 androuid 遍历一个 view 下面的子view // 保存 btnSaveRout.setOnClickListener(new OnClickListener() { @Overr ...
- docker 个人遇到问题日志记录
system: openSUSE Leap 42.3 在openSUSE中可直接运行" sudo zypper in docker"进行安装docker-ce wakasann@l ...