标签:int up long 七分钟 maxn ans P4145 造题 query
区间开平方直接上暴力即可。
因为一个数开几次就到1了。
维护一个区间最大值,当该区间最大值是1的时候直接return。
复杂度O(nlognlogn)?
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e5+100;
int n,m;
long long a[maxn],c[maxn<<2],mx[maxn<<2];
void build (int i,int l,int r) {
if (l==r) {
c[i]=mx[i]=a[l];
return;
}
int mid=(l+r)>>1;
build(i<<1,l,mid);
build(i<<1|1,mid+1,r);
c[i]=c[i<<1]+c[i<<1|1];
mx[i]=max(mx[i<<1],mx[i<<1|1]);
}
void up (int i,int l,int r,int L,int R) {
if (mx[i]==1) return;
if (l==r) {
c[i]=sqrt(c[i]);
mx[i]=sqrt(mx[i]);
return;
}
int mid=(l+r)>>1;
if (L<=mid) up(i<<1,l,mid,L,R);
if (R>mid) up(i<<1|1,mid+1,r,L,R);
c[i]=c[i<<1]+c[i<<1|1];
mx[i]=max(mx[i<<1],mx[i<<1|1]);
}
long long query (int i,int l,int r,int L,int R) {
if (l>=L&&r<=R) return c[i];
int mid=(l+r)>>1;
long long ans=0;
if (L<=mid) ans+=query(i<<1,l,mid,L,R);
if (R>mid) ans+=query(i<<1|1,mid+1,r,L,R);
return ans;
}
int main () {
scanf("%d",&n);
for (int i=1;i<=n;i++) scanf("%lld",a+i);
build(1,1,n);
int q;
scanf("%d",&q);
while (q--) {
int k,l,r;
scanf("%d%d%d",&k,&l,&r);
if (l>r) swap(l,r);
if (k==0) {
up(1,1,n,l,r);
}
else {
printf("%lld\n",query(1,1,n,l,r));
}
}
}
标签:int,up,long,七分钟,maxn,ans,P4145,造题,query 来源: https://www.cnblogs.com/zhanglichen/p/15041453.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。