H.Tree Recovery
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 131072K,其他语言262144K
64bit IO Format: %lld
链接:https://www.nowcoder.com/acm/contest/77/H
来源:牛客网

题目描述

You have N integers, A1A2, ... , AN. You need to deal with two kinds of operations. One type of operation is to add some given number to each number in a given interval. The other is to ask for the sum of numbers in a given interval.

输入描述:

输出描述:

You need to answer all Q commands in order. One answer in a line.
示例1

输入

10 5
1 2 3 4 5 6 7 8 9 10
Q 4 4
Q 1 10
Q 2 4
C 3 6 3
Q 2 4

输出

4
55
9
15

这个题是线段树区间查询求和和区间更新。

代码:

  1 /*2 //H-线段树-区间查询求和和区间更新3 #include<iostream>4 #include<cstring>5 #include<cstdio>6 #include<cstdlib>7 #include<algorithm>8 using namespace std;9 typedef long long ll;10 #define ls l,m,rt<<111 #define rs m+1,r,rt<<1|112 #define root 1,n,113 const int maxn=1e5+10;14 ll Sum[maxn<<2],Add[maxn<<2];//Sum为求和,Add为懒惰标记15 ll A[maxn],n;//存原数组数据下标16 17 //PushUp函数更新节点信息,这里是求和18 void PushUp(int rt){19     Sum[rt]=Sum[rt<<1]+Sum[rt<<1|1];20 }21 22 //下推标记的函数23 void PushDown(int rt,int m){24     if(Add[rt]){//下推标记25         Add[rt<<1]+=Add[rt];26         Add[rt<<1|1]+=Add[rt];27         Sum[rt<<1]+=Add[rt]*(m-(m>>1));28         Sum[rt<<1|1]+=Add[rt]*(m>>1);29         Add[rt]=0;//清除本节点标记30     }31 }32 33 //建树34 void Build(int l,int r,int rt){//rt表示当前节点编号35     Add[rt]=0;36     if(l==r){37         Sum[rt]=A[l];return;38     }39     int m=(l+r)>>1;40     Build(ls);41     Build(rs);42     PushUp(rt);43 }44 45 //区间修改A[L,R]+=C46 void Update(int L,int R,int C,int l,int r,int rt){47     if(L<=l&&r<=R){48         Sum[rt]+=(ll)C*(r-l+1);49         Add[rt]+=C;50         return ;51     }52     PushDown(rt,r-l+1);//下推标记53     int m=(l+r)>>1;54     if(L<=m)Update(L,R,C,ls);55     if(R>m)Update(L,R,C,rs);56     PushUp(rt);//更新本节点57 }58 59 //区间查询A[L,R]的和60 int Query(int L,int R,int l,int r,int rt){61     if(L<=l&&r<=R){62         return Sum[rt];63     }64     PushDown(rt,r-l+1);//下推标记,否则Sum可能不正确65     int m=(l+r)>>1;66     ll ANS=0;//累计答案67     if(L<=m)ANS+=Query(L,R,ls);68     if(R>m)ANS+=Query(L,R,rs);69     return ANS;70 }71 72 int main(){73     int n,m;74     scanf("%d%d",&n,&m);75     for(int i=1;i<=n;i++)76         scanf("%lld",&A[i]);77     Build(1,n,1);//建树78     while(m--){79         char str[2];80         scanf("%s",str);81         if(str[0]=='Q'){82             int a,b;83             scanf("%d%d",&a,&b);84             ll ANS=Query(a,b,root);//区间查询85             printf("%lld\n",ANS);86         }87         else{88             int a,b,C;89             scanf("%d%d%d",&a,&b,&C);90             Update(a,b,C,root);//区间修改91         }92     }93     return 0;94 }95 */96 /*97 样例98 10 599 1 2 3 4 5 6 7 8 9 10
100 Q 4 4
101 Q 1 10
102 Q 2 4
103 C 3 6 3
104 Q 2 4
105 */

就这样,还有二维线段树,还没写,以后写。

滚去看搜索了,简直被虐爆了,难受。

转载于:https://www.cnblogs.com/ZERO-/p/9711387.html

牛客网 2018年全国多校算法寒假训练营练习比赛(第五场) H.Tree Recovery-完全版线段树(区间更新、区间求和)...相关推荐

  1. 【题集】牛客网·2018年全国多校算法寒假训练营练习比赛(第二场)

    原文链接:2018年全国多校算法寒假训练营练习比赛(第二场) A 吐泡泡 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536K 64bit IO Form ...

  2. 【题集·待解决】牛客网·2018年全国多校算法寒假训练营练习比赛(第二场)

    原文链接:2018年全国多校算法寒假训练营练习比赛(第二场) A 吐泡泡 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536K 64bit IO Form ...

  3. 牛客网 2018年全国多校算法寒假训练营练习比赛(第二场) A.吐泡泡-STL(stack)

    不好玩,一堆板子,太菜了,被打爆了,B一直wa60%,D一直wa80%,D改了多组输入就过了... A.吐泡泡 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言6 ...

  4. 牛客网 2018年全国多校算法寒假训练营练习比赛(第二场) H.了断局-递推

    H.了断局 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536K 64bit IO Format: %lld 链接:https://www.nowcode ...

  5. 牛客网2018年全国多校算法寒假训练营练习比赛(第二场)

    A-吐泡泡 链接:https://www.nowcoder.com/acm/contest/74/A 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语 ...

  6. 牛客网 2018年全国多校算法寒假训练营练习比赛(第一场) 题解

    A-大吉大利,今晚吃鸡--枪械篇 题目描述 在绝地求生(吃鸡)游戏里,不同的枪支有不同的威力,更是可以搭配不同的配件,以提升枪支的性能. 每一把枪都有其威力及其可装备配件种类.每一个配件有其所属种类, ...

  7. 牛客网 2018年全国多校算法寒假训练营练习比赛(第二场) 题解

    A-吐泡泡 题目描述 小鱼儿吐泡泡,嘟嘟嘟冒出来.小鱼儿会吐出两种泡泡:大泡泡"O",小泡泡"o". 两个相邻的小泡泡会融成一个大泡泡,两个相邻的大泡泡会爆掉. ...

  8. 牛客网阶乘怪物C语言,【题集】牛客网·2018年全国多校算法寒假训练营练习比赛(第二场)(示例代码)...

    时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536K 64bit IO Format: %lld 题目描述 小鱼儿吐泡泡,嘟嘟嘟冒出来.小鱼儿会吐出两种泡 ...

  9. 牛客网 2018年全国多校算法寒假训练营练习比赛(第三场)D.小牛vs小客-博弈

    菜哭... D.小牛vs小客 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536K 64bit IO Format: %lld 链接:https://ww ...

最新文章

  1. 看到一个flash做的超酷网站
  2. iOS上相见恨晚的6个APP
  3. ​KDD 2020 开源论文 | 图神经网络多变量时序预测
  4. UNION JOIN 连接表
  5. python输错了怎么办_python怎么实现输错三次密码之后锁定
  6. python从入门到精通百度云资源-Python从入门到精通(资源汇总)
  7. git branch看不到分支_最好的Git分支管理教程
  8. 四大顶级开源网络管理工具详解
  9. iostream头文件简单理解
  10. 申请与认证IB课程全流程
  11. CDN月95计费方式
  12. Python 菜单中的分割线
  13. 工作前5年决定你一生的财富
  14. [基础服务] 常用邮箱服务地址
  15. 几道加油站加油相关问题:最小加油次数、能否回到起点
  16. 水果店如何写文案,做水果店发的文案
  17. 云借阅-图书管理系统
  18. 用爬虫批量采集阿里巴巴1688商品数据
  19. Nsight compute远程连接不上
  20. PMP精华集合:学习PMP最关心的10大问题,你必须要知道

热门文章

  1. 3l如何使用_慢阻肺患者如何选购呼吸机和制氧机,需要注意哪些?
  2. c语言行列式源代码,新手作品:行列式计算C语言版
  3. python调用linux命令输出结果,Python-运行shell命令并捕获输出
  4. edmonds算法matlab,匈牙利算法的matlab实现
  5. centos 7.6安装java_Hadoop的安装
  6. C语言中return的各种用法
  7. 完数c++语言程序_C语言经典100题(19)
  8. 虚拟空间独立服务器哪个好,共享虚拟主机和独立哪个好
  9. Windows下使用net user命令管理账户
  10. cd mysql 权限不够_.bash_profile权限不够_cdmysql权限不够