UESTC 1057 - 秋实大哥与花

线段树第一题,自己把模板一点点慢慢码出来。

线段树讲解:http://www.cnblogs.com/TenosDoIt/p/3453089.html

有一些注意点,比如要开4倍的MAXN,否则在数据较大时会RE,引用来自CSDN上的一段话:

 1 #include<cstdio>
 2 #define MAXN 100000+5
 3 typedef long long ll;
 4 struct Node{
 5     int l,r;
 6     ll sum,lazy;
 7     void update(ll x)
 8     {
 9         sum+=(r-l+1)*x;
10         lazy+=x;
11     }
12 }node[4*MAXN];
13 int n,m,a[MAXN];
14 void pushdown(int root)
15 {
16     if(node[root].lazy)
17     {
18         node[root*2].update(node[root].lazy);
19         node[root*2+1].update(node[root].lazy);
20         node[root].lazy=0;
21     }
22 }
23 void pushup(int root)
24 {
25     node[root].sum=node[root*2].sum+node[root*2+1].sum;
26 }
27 void build(int root,int l,int r)
28 {
29     node[root].l=l; node[root].r=r;
30     node[root].sum=0; node[root].lazy=0;
31     if(l==r) node[root].sum=a[l];
32     else
33     {
34         int mid=l+(r-l)/2;
35         build(root*2,l,mid);
36         build(root*2+1,mid+1,r);
37         pushup(root);
38     }
39 }
40 void update(int root,int st,int ed,int val)
41 {
42     if(st>node[root].r || ed<node[root].l) return;
43     if(st<=node[root].l && node[root].r<=ed) node[root].update(val);
44     else
45     {
46         pushdown(root);
47         update(root*2,st,ed,val);
48         update(root*2+1,st,ed,val);
49         pushup(root);
50     }
51 }
52 ll query(int root,int st,int ed)
53 {
54     if(ed<node[root].l || node[root].r<st) return 0;
55     if(st<=node[root].l && node[root].r<=ed) return node[root].sum;
56     else
57     {
58         ll ans=0;
59         pushdown(root);
60         ans+=query(root*2,st,ed);
61         ans+=query(root*2+1,st,ed);
62         pushup(root);
63         return ans;
64     }
65 }
66 int main()
67 {
68     scanf("%d",&n);
69     for(int i=1;i<=n;i++) scanf("%d",&a[i]);
70     build(1,1,n);
71     scanf("%d",&m);
72     for(int i=1;i<=m;i++)
73     {
74         int l,r,v;
75         scanf("%d%d%d",&l,&r,&v);
76         update(1,l,r,v);
77         printf("%lld\n",query(1,l,r));
78     }
79 }
时间: 2024-08-29 08:38:38

UESTC 1057 - 秋实大哥与花的相关文章

CDOJ 1057 秋实大哥与花 线段树 区间更新+区间查询

链接: I - 秋实大哥与花 Time Limit:1000MS     Memory Limit:65535KB     64bit IO Format:%lld & %llu Submit Status Practice UESTC 1057 Appoint description:  System Crawler  (2016-04-19) Description 秋实大哥是一个儒雅之人,昼听笙歌夜醉眠,若非月下即花前. 所以秋实大哥精心照料了很多花朵.现在所有的花朵排成了一行,每朵花有一

UESTC_秋实大哥与花 2015 UESTC Training for Data Structures&lt;Problem B&gt;

B - 秋实大哥与花 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit Status 秋实大哥是一个儒雅之人,昼听笙歌夜醉眠,若非月下即花前. 所以秋实大哥精心照料了很多花朵.现在所有的花朵排成了一行,每朵花有一个愉悦值. 秋实大哥每天要对着某一段连续的花朵歌唱,然后这些花朵的愉悦值都会增加一个相同的值v(v可能为负). 同时他想知道每次他唱完歌后这一段连续的花朵的

UESTC 1073 秋实大哥与线段树(线段树---省时的建树)

题目链接:http://acm.uestc.edu.cn/#/problem/show/1073 “学习本无底,前进莫徬徨.” 秋实大哥对一旁玩手机的学弟说道. 秋实大哥是一个爱学习的人,今天他刚刚学习了线段树这个数据结构. 为了检验自己的掌握程度,秋实大哥给自己出了一个题,同时邀请大家一起来作. 秋实大哥的题目要求你维护一个序列,支持两种操作:一种是修改某一个元素的值:一种是询问一段区间的和. Input 第一行包含一个整数n ,表示序列的长度. 接下来一行包含n  个整数a i  ,表示序列

UESTC 1061 秋实大哥与战争 线段树区间合并

秋实大哥与战争 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) 男儿何不带吴钩,收取关山五十州. 征战天下是秋实大哥一生的梦想,所以今天他又在练习一个对战游戏. 秋实大哥命令所有士兵从左到右排成了一行来抵挡敌人的攻击. 敌方每一次会攻击一个士兵,这个士兵就会阵亡,整个阵列就会从这个位置断开:同时有的时候已阵亡的士兵会受人赢气息感染而复活. 秋实大哥想知道某一时刻某一个士兵所在的

uestc 1073 秋实大哥与线段树 Label:线段树

秋实大哥与线段树 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) “学习本无底,前进莫徬徨.” 秋实大哥对一旁玩手机的学弟说道. 秋实大哥是一个爱学习的人,今天他刚刚学习了线段树这个数据结构. 为了检验自己的掌握程度,秋实大哥给自己出了一个题,同时邀请大家一起来作. 秋实大哥的题目要求你维护一个序列,支持两种操作:一种是修改某一个元素的值:一种是询问一段区间的和. Input

UESTC 1063 秋实大哥与妹子(二叉堆)

题目链接: 点我跳转~ 题意: 求中位数. 注意事项: (1)n最大为250000. (2)内存限制大小为1500KB. 思路: 由于内存限制,只能开大概 n/2 大小的数组.如果 n 为偶数,排序之后,中位数的位置会出现在 n/2,和 n/2 + 1, 而如果 n 为奇数则中位数的位置在 n/2 + 1,所以数组大小开 n/2 + 1.首先对前 n/2 + 1个数字建立一个大根堆.对于之后的 输入维护这个大根堆.输入完成之后进行排序,根据 n 的奇偶来选择堆中最大,或第一第二大的数字求出中位数

UESTC 1059 秋实大哥与小朋友(线段树 + 离散化)

Description 秋实大哥以周济天下,锄强扶弱为己任,他常对天长叹:安得广厦千万间,大庇天下寒士俱欢颜. 所以今天他又在给一群小朋友发糖吃. 他让所有的小朋友排成一行,从左到右标号.在接下去的时间中,他有时会给一段区间的小朋友每人v v 颗糖,有时会问第x x 个小朋友手里有几颗糖. 这对于没上过学的孩子来说实在太困难了,所以你看不下去了,请你帮助小朋友回答所有的询问. Input 第一行包含两个整数n  ,m  ,表示小朋友的个数,以及接下来你要处理的操作数. 接下来的m  行,每一行表

UESTC 1073 秋实大哥与线段树 (线段树)

“学习本无底,前进莫徬徨.” 秋实大哥对一旁玩手机的学弟说道. 秋实大哥是一个爱学习的人,今天他刚刚学习了线段树这个数据结构. 为了检验自己的掌握程度,秋实大哥给自己出了一个题,同时邀请大家一起来作. 秋实大哥的题目要求你维护一个序列,支持两种操作:一种是修改某一个元素的值:一种是询问一段区间的和. Input 第一行包含一个整数nn,表示序列的长度. 接下来一行包含nn个整数aiai,表示序列初始的元素. 接下来一行包含一个整数mm,表示操作数. 接下来mm行,每行是以下两种操作之一: 1 x

UESTC 1091秋实大哥の恋爱物语 [偏移模式匹配]

题目链接:http://acm.uestc.edu.cn/#/problem/show/1091 题目大意:求模式串p,在s中出现的次数,但是p能平移到s即可,比如s: 1 3 4和 p :0 2 3: 题目思路:处理出每一位相对前一位的变化,然后KMP即可: 代码: //author:ACsorry //result:Yes #include<iostream> #include<cstdio> #include<cstring> #include<cmath&