传送门

维护区间开方,区间求和。这个是线段树常规操作。

显然一个数被开方若干次之后要么是1,要么是0,所以用线段树维护区间最大和区间和,如果区间最大不超过1就剪枝剪掉,不然就继续递归直到叶节点时停下进行单点修改。

虽然这方法看起来很暴力,但实际上由于只有开方这一个操作,时间复杂度是有保障的。

代码如下:

#include<bits/stdc++.h>
#define N 100005
#define ll long long
#define lc (p<<1)
#define rc (p<<1|1)
#define mid (T[p].l+T[p].r>>1)
using namespace std;
struct Node{int l,r;ll maxn,sum;}T[N<<2];
ll a[N];
int n,m;
inline ll read(){
    ll ans=0;
    char ch=getchar();
    while(!isdigit(ch))ch=getchar();
    while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
    return ans;
}
inline void write(ll x){
    if(x>9)write(x/10);
    putchar((x%10)^48);
}
inline ll max(ll a,ll b){return a>b?a:b;}
inline void pushup(int p){T[p].maxn=max(T[lc].maxn,T[rc].maxn),T[p].sum=T[lc].sum+T[rc].sum;}
inline void build(int p,int l,int r){
    T[p].l=l,T[p].r=r;
    if(l==r){T[p].maxn=T[p].sum=a[l];return;}
    build(lc,l,mid);
    build(rc,mid+1,r);
    pushup(p);
}
inline void update(int p,int ql,int qr){
    if(T[p].l>qr||T[p].r<ql||T[p].maxn<=1)return;
    if(T[p].l==T[p].r){T[p].maxn=T[p].sum=sqrt(T[p].maxn);return;}
    if(qr<=mid)update(lc,ql,qr);
    else if(ql>mid)update(rc,ql,qr);
    else update(lc,ql,mid),update(rc,mid+1,qr);
    pushup(p);
}
inline ll query(int p,int ql,int qr){
    if(T[p].l>qr||T[p].r<ql)return 0;
    if(ql<=T[p].l&&T[p].r<=qr)return T[p].sum;
    if(qr<=mid)return query(lc,ql,qr);
    if(ql>mid)return query(rc,ql,qr);
    return query(lc,ql,mid)+query(rc,mid+1,qr);
}
int main(){
    n=read();
    for(int i=1;i<=n;++i)a[i]=read();
    build(1,1,n);
    m=read();
    while(m--){
        int op=read(),l=read(),r=read();
        if(l>r)l^=r,r^=l,l^=r;
        switch(op){
            case 2:{update(1,l,r);break;}
            default:{write(query(1,l,r)),puts("");break;}
        }
    }
    return 0;
}

最新文章

  1. PSR规范
  2. js 日期
  3. JS对象之间的关系
  4. 三大域对象的使用总结request域 + session域 +
  5. C++:异常的处理
  6. yeoman运行grunt serve 提示错误
  7. AE与AO的区别
  8. webservice跨服务器上传附件
  9. vue的Virtual Dom实现- snabbdom解密
  10. Spring-java-模板设计模式
  11. How To determine DDIC Check Table, Domain and Get Table Field Text Data For Value?
  12. 在echarts里在geojson绘制的地图上展示散点图(气泡)、线集。
  13. ==还款-代偿(csv循环自动代偿)
  14. 移植busybox构建最小根文件系统
  15. docker私有仓库pull/push
  16. IOS 单击手势和cell点击冲突
  17. mysql的.sql文件头部 /*!32312 IF NOT EXISTS*/;
  18. Spring Boot 使用IntelliJ IDEA创建一个web开发实例(四)
  19. oc 第五天(内存管理)
  20. java线程总结1--线程的一些概念基础以及线程状态

热门文章

  1. java Export Excel POI 转
  2. gevent 实现单线程下的socket链接
  3. as3 文档类判断是否被加载
  4. Simple2D-19(音乐播放器)播放器的源码实现
  5. visual stdio 工程 宏
  6. vue 解决报错1
  7. python 刷题必备
  8. eclipse zg项目学习
  9. xpath的层级与逻辑定位
  10. springboot取得resources下的文件