HDU 1754 I Hate It(线段树之单点更新,区间最值)
I Hate It
Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 70863 Accepted Submission(s): 27424
不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问。当然,老师有时候需要更新某位同学的成绩。
Huge input,the C function scanf() will work better than cin
- #include <bits/stdc++.h>
- using namespace std;
- #define maxsize 200020
- typedef struct
- {
- int left,right;
- int maxn;
- }Node;
- int n,m;
- int num[maxsize];
- Node tree[maxsize*];
- int buildtree(int root,int left,int right)// 构建线段树
- {
- int mid;
- tree[root].left=left;
- tree[root].right=right;// 当前节点所表示的区间
- if(left==right)// 左右区间相同,则此节点为叶子,max 应储存对应某个学生的值
- return tree[root].maxn=num[left];
- mid=(left+right)/;
- int a,b;// 递归建立左右子树,并从子树中获得最大值
- a=buildtree(*root,left,mid);
- b=buildtree(*root+,mid+,right);
- return tree[root].maxn=max(a,b);
- }
- int find(int root,int left,int right)// 从节点 root 开始,查找 left 和 right 之间的最大值
- {
- int mid;
- if(tree[root].left>right||tree[root].right<left)// 若此区间与 root 所管理的区间无交集
- return ;
- if(left<=tree[root].left&&tree[root].right<=right)// 若此区间包含 root 所管理的区间
- return tree[root].maxn;
- mid=(left+right)/;
- int a,b;// 若此区间与 root 所管理的区间部分相交
- a=find(*root,left,right);
- b=find(*root+,left,right);
- return max(a,b);
- }
- int update(int root,int pos,int val)// 更新 pos 点的值
- {
- if(pos<tree[root].left||pos>tree[root].right)// 若 pos 不存在于 root 所管理的区间内
- return tree[root].maxn;
- if(tree[root].left==pos&&tree[root].right==pos)// 若 root 正好是一个符合条件的叶子
- return tree[root].maxn=val;
- int a,b;// 否则。。。。
- a=update(*root,pos,val);
- b=update(*root+,pos,val);
- tree[root].maxn=max(a,b);
- return tree[root].maxn;
- }
- int main()
- {
- char c;
- int i;
- int x,y;
- while(scanf("%d%d",&n,&m)!=EOF)
- {
- for(i=;i<=n;i++)
- scanf("%d",&num[i]);
- buildtree(,,n);
- for(i=;i<=m;i++)
- {
- getchar();
- scanf("%c%d%d",&c,&x,&y);
- if(c=='Q')
- printf("%d\n",find(,x,y));
- else
- {
- num[x]=y;
- update(,x,y);
- }
- }
- }
- return ;
- }
HDU 1754 I Hate It(线段树之单点更新,区间最值)的更多相关文章
- HDU 1754 I Hate It(线段树之单点更新 区间最值查询)
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- hdu 1754 I Hate It(线段树之 单点更新+区间最值)
I Hate It Time Limit: 90 ...
- hdu 1754 I Hate It (线段树、单点更新)(PS:ios::sync_with_stdio(false)可以加快cin、cout的读取写出速度)
I Hate ItTime Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- HDU 3577 Fast Arrangement ( 线段树 成段更新 区间最值 区间最大覆盖次数 )
线段树成段更新+区间最值. 注意某人的乘车区间是[a, b-1],因为他在b站就下车了. #include <cstdio> #include <cstring> #inclu ...
- hdu 1754 线段树(单点替换 区间最值)
Sample Input5 61 2 3 4 5Q 1 5 //1-5结点的最大值U 3 6 //将点3的数值换成6Q 3 4Q 4 5U 2 9Q 1 5 Sample Output5659 # i ...
- hdu 1166 敌兵布阵 (线段树、单点更新)
敌兵布阵Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
- HDU 1540 Tunnel Warfare 平衡树 / 线段树:单点更新,区间合并
Tunnel Warfare Time Limit: 4000/2000 MS (Java/Others) Memory Lim ...
- hdu 敌兵布阵(线段树之单点更新)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- hdu 1754 I Hate It 线段树 点改动
// hdu 1754 I Hate It 线段树 点改动 // // 不多说,裸的点改动 // // 继续练 #include <algorithm> #include <bits ...
随机推荐
- JavaScript基础4——关于语句流程控制(分支语句、循环语句等)
分支语句 (1)if...else...语句,基本格式分三种,如下 <script type="text/javascript"> var i=50; //if语句 i ...
- 从初识Maven到使用Maven进行依赖管理和项目构建
前些天就安装了Maven,以备自己以后整合项目用,尤其是我们的ssh,ssm项目.想必好多人在开始的时候并不清楚Maven是什么,它能够帮助我们干什么. 所以在学习Maven之前我们一定要知道它是什么 ...
- 云储存第三方--阿里云OSS VS 又拍云USS
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Helvetica Neue"; color: #454545 } p. ...
- java 异常处理机制(java 编程思想)
一.概念 "异常"这个词有"我对此感到意外"的意思.问题出现了,你也许并不清楚该如何处理,但你的确知道不应该置之不理:你要停下来,看看是不是有别人或在别的地方, ...
- Spring拦截器总结
本文是对慕课网上"搞定SSM开发"路径的系列课程的总结,详细的项目文档和课程总结放在github上了.点击查看 Spring过滤器WebFilter可以配置中文过滤 拦截器实现步骤 ...
- 豹哥嵌入式讲堂:ARM开发中有用的文件(1)- source文件
大家好,我是豹哥,猎豹的豹,犀利哥的哥.今天豹哥给大家讲的是嵌入式开发里的source文件种类. 众所周知,嵌入式开发属于偏底层的开发,主要编程语言是C和汇编.所以本文要讲的source文件主要指的就 ...
- ArcGIS API for Javascript 加载天地图(墨卡托投影)
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- oracle 导入 dmp
执行命令 imp his/his@orcl File=/home/oracle/core_his50_common.dmp FULL=Y
- ABP架构学习系列三:手工搭建ABP框架
由于公司的项目才接触到ABP这个框架,当时就觉得高大上,什么IOC.AOP.ddd各种专业词汇让人激情 澎湃,但在使用过程中碰到了许多坑,可能也许是没有去看源码导致的,但工作确实没有那么多时间让人去慢 ...
- [Micropython]TPYBoardV102 Dfu固件烧写教程
TPYBoardv10x固件烧写一直是大家比较关心的问题,上次教大家用SWD接口烧写TPYBoard的固件,这次教大家用另一种方式烧写我们TPYBoardv10x的固件,直接用dfu模式烧写固件. 用 ...