| 比赛 |
2026.5.16 |
评测结果 |
AAAAAAAAAA |
| 题目名称 |
序列 |
最终得分 |
100 |
| 用户昵称 |
李金泽 |
运行时间 |
2.999 s |
| 代码语言 |
C++ |
内存使用 |
84.98 MiB |
| 提交时间 |
2026-05-16 11:02:48 |
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#define N 1000005
#define int long long
#define ul unsigned long long
#define fo(i,l,r) for(int i=l;i<=r;i++)
#define rf(i,r,l) for(int i=r;i>=l;i--)
using namespace std;
int n,m,k,d,a[N],op,x,y,z;
int s[N],st[N],t;
int lg[N],bz[21][N];
ul ans,f[N],g[N],sf[N],sg[N];
bool type;
int fp(int a,int n,int mod){
int ans=1;
while(n){
if(n&1)ans=ans*a%mod;
a=a*a%mod;
n>>=1;
}
return ans;
}
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int gs(int x,int y){
int k=lg[y-x+1];
return a[bz[k][x]]<a[bz[k][y-(1<<k)+1]]?bz[k][x]:bz[k][y-(1<<k)+1];
}
namespace gen{
typedef unsigned long long ull;
ull s,a,b,c,lastans=0;
ull rand(){
return s^=(a+b*lastans)%c;
}
};
int read(){
int sum=0;bool f=0;char c=getchar();
for(;c<48||c>57;c=getchar())if(c==45)f=1;
for(;c>=48&&c<=57;c=getchar())sum=sum*10+(c&15);
return f?-sum:sum;
}
signed main(){
freopen("sequence.in","r",stdin);freopen("sequence.out","w",stdout);
ios::sync_with_stdio(0);
cin.tie(0);
n=read();m=read();type=read();
fo(i,1,n)a[i]=read(),bz[0][i]=i;
fo(k,1,20)
fo(i,1,n-(1<<k)+1)
bz[k][i]=a[bz[k-1][i]]<a[bz[k-1][i+(1<<k-1)]]?bz[k-1][i]:bz[k-1][i+(1<<k-1)];
fo(i,2,n)lg[i]=lg[i>>1]+1;
fo(i,1,n){
while(t&&a[st[t]]>a[i])s[st[t--]]=i;
st[++t]=i;
}
while(t)s[st[t--]]=n+1;
rf(i,n,1)f[i]=a[i]*(s[i]-i)+f[s[i]];
rf(i,n,1){
while(t&&a[st[t]]>a[i])s[st[t--]]=i;
st[++t]=i;
}
while(t)s[st[t--]]=0;
fo(i,1,n)g[i]=a[i]*(i-s[i])+g[s[i]];
fo(i,1,n)sf[i]=sf[i-1]+f[i],sg[i]=sg[i-1]+g[i];
if(type)gen::s=read(),gen::a=read(),gen::b=read(),gen::c=read();
while(m--){
int l,r;
if(type){
l=gen::rand()%n+1;
r=gen::rand()%n+1;
if(l>r) std::swap(l,r);
}
else l=read(),r=read();
int i=gs(l,r);
ul sum=0;
sum+=(ul)(i-l+1)*(r-i+1)*a[i];
if(l<i)sum+=sf[i-1]-sf[l-1]-(i-l)*f[i];
if(i<r)sum+=sg[r]-sg[i]-(r-i)*g[i];
gen::lastans=sum;
ans^=sum;
}
printf("%llu",ans);
return 0;
}