设为首页 加入收藏

TOP

Can you answer these queries?(线段树之单点更新)
2015-07-20 17:16:13 来源: 作者: 【 】 浏览:3
Tags:Can you answer these queries 线段 单点 更新

萌萌哒的传送门


因为一个long long 范围内的数开方不会超过10次,所以题目就转化为线段树的单点更新问题.


#include 
  
   
#include 
   
     #include 
    
      #include 
     
       #include 
      
        #include 
       
         #include 
        
          #include 
         
           #include 
          
            #define ls u << 1 #define rs u << 1 | 1 #define lson l, mid, u << 1 #define rson mid + 1, r, u << 1 | 1 #define INF 0x3f3f3f3f using namespace std; typedef long long ll; const int M = 1e5 + 100; const int N = 1e7 + 100; ll sum[M << 2]; void pushup(int u){ sum[u] = sum[ls] + sum[rs]; } void build(int l,int r,int u){ if(l == r){ scanf("%I64d",sum + u); } else { int mid = (l + r) >> 1; build(lson); build(rson); pushup(u); } } void update(int L,int R,int l,int r,int u){ if(sum[u] == (r - l + 1)){ return; } if(l == r){ sum[u] = floor(sqrt((double)sum[u])); } else { int mid = (l + r) >> 1; if(L <= mid) update(L,R,lson); if(R > mid) update(L,R,rson); pushup(u); } } ll query(int L,int R,int l,int r,int u){ if(L <= l && R >= r){ return sum[u]; } else { int mid = (l + r) >> 1; ll res = 0; if(L <= mid) res += query(L,R,lson); if(R > mid) res += query(L,R,rson); return res; } } int main(){ //freopen("in","r",stdin); int n,m,cnt = 0; while(~scanf("%d",&n)){ build(1,n,1); scanf("%d",&m); printf("Case #%d:\n",++cnt); while(m--){ int t,l,r; scanf("%d %d %d",&t,&l,&r); if(l > r) swap(l,r); if(!t) update(l,r,1,n,1); else { printf("%I64d\n",query(l,r,1,n,1)); } } puts(""); } return 0; } 
          
         
        
       
      
     
    
   
  



】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇HDU 2586 How far away ? (离线L.. 下一篇c++ 模板之 抽象工厂

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·怎样用 Python 写一 (2025-12-27 02:49:19)
·如何学习python数据 (2025-12-27 02:49:16)
·想要自学数据分析, (2025-12-27 02:49:14)
·Java 集合框架 - 菜 (2025-12-27 02:19:36)
·Java集合框架最全详 (2025-12-27 02:19:33)