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): 76334    Accepted Submission(s):
29413
这让很多学生很反感。
不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问。当然,老师有时候需要更新某位同学的成绩。
在每个测试的第一行,有两个正整数 N 和 M (
0<N<=200000,0<M<5000
),分别代表学生的数目和操作的数目。
学生ID编号分别从1编到N。
第二行包含N个整数,代表这N个学生的初始成绩,其中第i个数代表ID为i的学生的成绩。
接下来有M行。每一行有一个字符
C (只取'Q'或'U')
,和两个正整数A,B。
当C为'Q'的时候,表示这是一条询问操作,它询问ID从A到B(包括A,B)的学生当中,成绩最高的是多少。
当C为'U'的时候,表示这是一条更新操作,要求把ID为A的学生的成绩更改为B。
1 2 3 4 5
Q 1 5
U 3 6
Q 3 4
Q 4 5
U 2 9
Q 1 5
6
5
9
Huge input,the C function scanf() will work better than cin
#include<cstdio> const int N=;
char a[];
int p,q;
int sum[N*];
int read(){
int x=,f=;char c=getchar();
while(c<''||c>''){if(c=='-')f=-;c=getchar();}
while(c<=''&&c>=''){x=x*+c-'';c=getchar();}return x*f;}
int max(int x,int y)
{
if(x>y)return x;
return y;
}
void update(int rt)
{
sum[rt]=max(sum[rt<<],sum[rt<<|]);
}
void build(int l,int r,int rt)
{
if(l==r){
sum[rt]=read(); return ;
}
int mid=(l+r)>>;
build(l,mid,rt<<);
build(mid+,r,rt<<|);
update(rt);
}
void modify(int l,int r,int rt)
{
if(r==l){
sum[rt]=q;return;
}
int mid=(l+r)>>;
if(mid>=p) modify(l,mid,rt<<);
else modify(mid+,r,rt<<|);
update(rt);
} int query(int l,int r,int rt,int nowl,int nowr)
{
if(nowl<=l&&nowr>=r)
{
return sum[rt];
}
int m=(r+l)>>;
int ans=;
if(nowl<=m) ans=max(ans,query(l,m,rt<<,nowl,nowr));
if(nowr>m) ans=max(ans,query(m+,r,rt<<|,nowl,nowr));
return ans;
} int main()
{
int n,m;
while(scanf("%d%d",&n,&m)==)
{
build(,n,);
while(m--)
{
scanf("%s",a);
p=read();q=read();
if(a[]=='U')modify(,n,);
else if(a[]=='Q')printf("%d\n",query(,n,,p,q));
}
}
return ;
}
HDU 1754 I Hate It<区间最值 单点修改>的更多相关文章
- HDU 1754(线段树区间最值)
		I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ... 
- HDU 1754 I Hate It 【线段树单点修改 维护区间最大值】
		题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1754 I Hate It Time Limit: 9000/3000 MS (Java/Others ... 
- HDU - 1754 I Hate It (线段树单点修改,求区间最大值)
		很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问.当然,老师有 ... 
- HUD.2795 Billboard ( 线段树 区间最值 单点更新 单点查询 建树技巧)
		HUD.2795 Billboard ( 线段树 区间最值 单点更新 单点查询 建树技巧) 题意分析 题目大意:一个h*w的公告牌,要在其上贴公告. 输入的是1*wi的w值,这些是公告的尺寸. 贴公告 ... 
- HDU 1754 I Hate It(线段树单点更新区间最值查询)
		I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ... 
- HDU 1754——I Hate It——————【线段树单点替换、区间求最大值】
		I Hate It Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit St ... 
- HDU 5289 Assignment (二分+区间最值)
		[题目链接]click here~~ [题目大意]: 给出一个数列,问当中存在多少连续子序列,子序列的最大值-最小值<k [思路]:枚举数列左端点.然后二分枚举右端点,用ST算法求区间最值.(或 ... 
- HDU 1754 I Hate It(线段树之单点更新,区间最值)
		I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ... 
- hdu 1754 splay tree伸展树 初战(单点更新,区间属性查询)
		题意:与区间查询点更新,点有20W个,询问区间的最大值.曾经用线段树,1000+ms,今天的伸展树,890没ms,差不多. 第一次学习伸展树,一共花了2个单位时间,感觉伸展树真很有用,也很好玩.现在只 ... 
随机推荐
- 【BZOJ 4605】崂山白花蛇草水 替罪羊树套线段树
			外层是借鉴了kd-tree的替罪羊里层是线段树,插入就是正常插入+拍扁重建,查询的时候,我们就像树状数组套线段树一样操作在替罪羊中找到的线段树根节点,但是对于在kd-tree查找过程中遇到的单点,我们 ... 
- centos6上使用fpm打python2.7 rpm包并兼容python2.6
			centos6上使用fpm打python2.7 rpm包并兼容python2.6 作者 运维小兵_加油 关注 2016.09.22 00:28 字数 501 阅读 45评论 0喜欢 1 工作中我们常常 ... 
- fs.watch 爬坑
			上星期用 fs.watch 和 readline.createInterface 对pm2的合并日志做了监控,根据指定的错误信息重启服务 发现不管是手动vim编辑日志,还是等待日志自动输出. fs.w ... 
- iconfont字体图标
			1.1.进入阿里图标网站 http://www.iconfont.cn/ 1.2.在购物车里添加自己需要的字体图标 1.3.下载代码 1.4.解压过后,找到iconfont.css,放在你的项目里,需 ... 
- java简单发送邮件
			需要的jar 据说是: <dependency> <groupId>javax.mail</groupId> <artifactId>mail</ ... 
- JSON各种转换总结
			JSONObject,JSONArray,Map,String之间转换 http://blog.csdn.net/superit401/article/details/51727739 1.Strin ... 
- org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'GET' not supported解决!
			org.springframework.web.HttpRequestMethodNotSupportedException: Request method 'GET' not supported解决 ... 
- 【洛谷 P1651】 塔 (差值DP)
			题目链接 题意:\(n\)个木块放到两个塔里,每个木块可放可不放,使得两塔高度相同且高度最大,求最大高度. 这个差值\(DP\)的思维难度还是很大的,没想出来,我就打了一个\(dfs\)骗了好像\(2 ... 
- [ CodeVS冲杯之路 ] P2456
			不充钱,你怎么AC? 题目:http://codevs.cn/problem/2456/ 用贪心的思想,木材当然要尽量分成多的木板,而大的木材能够分成大木板,但是小的木材不一定能够分成大的木板,所以木 ... 
- [bzoj2594][Wc2006]水管局长数据加强版——lct+离线
			Brief Description 您有一个无向带权图,您需要支持两种操作. 询问两个点之间的最大权最小路径. 删除一条边. Algorithm Design 我们首先提出一个猜想:最优路径一定在原图 ... 
