HDU 1754 I Hate It 线段树RMQ
I Hate It
Time Limit: 1 Sec Memory Limit: 256 MB
题目连接
http://acm.hdu.edu.cn/showproblem.php?pid=1754
Description
这让很多学生很反感。
不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问。当然,老师有时候需要更新某位同学的成绩。
Input
在每个测试的第一行,有两个正整数 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。
Output
Sample Input
5 6 1 2 3 4 5 Q 1 5 U 3 6 Q 3 4 Q 4 5 U 2 9 Q 1 5
Sample Output
HINT
题意
线段树RMQ,单点更新,区间查询最大值
题解:
线段树RMQ,单点更新,区间查询最大值
代码:
//qscqesze #include <cstdio> #include <cmath> #include <cstring> #include <ctime> #include <iostream> #include <algorithm> #include <set> #include <vector> #include <sstream> #include <queue> #include <typeinfo> #include <fstream> #include <map> typedef long long ll; using namespace std; //freopen("D.in","r",stdin); //freopen("D.out","w",stdout); #define sspeed ios_base::sync_with_stdio(0);cin.tie(0) #define maxn 205001 #define mod 10007 #define eps 1e-9 //const int inf=0x7fffffff; //无限大 const int inf=0x3f3f3f3f; /* inline ll read() {int x=0,f=1;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f; } */ //**************************************************************************************int n,q,a[maxn]; struct data{int l,r,mn; }tr[maxn*10]; void build(int k,int s,int t) {tr[k].l=s;tr[k].r=t;if(s==t){tr[k].mn=a[s];return;}int mid=(s+t)>>1;build(k<<1,s,mid);build(k<<1|1,mid+1,t);tr[k].mn=max(tr[k<<1].mn,tr[k<<1|1].mn); } int ask(int k,int s,int t) {int l=tr[k].l,r=tr[k].r;if(s==l&&t==r)return tr[k].mn;int mid=(l+r)>>1;if(t<=mid)return ask(k<<1,s,t);if(s>mid)return ask(k<<1|1,s,t);return max(ask(k<<1,s,mid),ask(k<<1|1,mid+1,t)); } void update(int k,int x,int y) {int l=tr[k].l,r=tr[k].r;if(l==r){tr[k].mn=y;return;}int mid=(l+r)>>1;if(x<=mid)update(k<<1,x,y);if(x>mid)update(k<<1|1,x,y);tr[k].mn=max(tr[k<<1].mn,tr[k<<1|1].mn); } int main() {//ios_base::sync_with_stdio(0);cin.tie(0);while(scanf("%d%d",&n,&q)!=EOF){memset(a,0,sizeof(a));memset(tr,0,sizeof(tr));for(int i=1;i<=n;i++)scanf("%d",&a[i]);build(1,1,n);for(int i=1;i<=q;i++){char t;int x,y;cin>>t;scanf("%d%d",&x,&y);if(t=='Q')printf("%d\n",ask(1,x,y));else update(1,x,y);}}return 0; }
HDU 1754 I Hate It 线段树RMQ相关推荐
- HDU 1754 I Hate It 线段树
I Hate It Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要 ...
- HDU 1166 敌兵布阵(线段树:点更新,区间求和)
HDU 1166 敌兵布阵(线段树:点更新,区间求和) http://acm.hdu.edu.cn/showproblem.php?pid=1166 题意: 给你n个整数,然后给你多条命令,每条命令如 ...
- HDU 3016 Man Down (线段树+dp)
HDU 3016 Man Down (线段树+dp) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- 2019CCPC网络赛 1002 HDU 6703(权值线段树)
2019CCPC网络赛 1002 HDU 6703(权值线段树) 思路:用权值线段树存题目给的数据后,2操作就是求权值线段树中大于等于k的部分中,靠近左端点的第一个大于r的值(这个求出来的只是原序列中 ...
- 【HDU - 5875】Function(线段树,区间第一个小于某个数的数 或 RMQ二分)
题干: The shorter, the simpler. With this problem, you should be convinced of this truth. You a ...
- HDU 6070 Dirt Ratio(线段树、二分)
http://acm.hdu.edu.cn/showproblem.php?pid=6070 题解 首先不难看出错误率是单调的,那么我们可以直接二分答案x,某个区间的错误率=区间数的种类cnt/区间长 ...
- hdu 5692 Snacks(dfs序+线段树区间更新)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5692 解题思路:这道题是树节点的点权更新,而且涉及到子树,常用的思路是利用dfs序,用线段树来对区间进 ...
- HDU 6089 Rikka with Terrorist (线段树)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=6089 题解 这波强行维护搞得我很懵逼... 扫描线,只考虑每个点能走到左上方(不包括正上方,但包括正左 ...
- CodeForces - 1422F Boring Queries(主席树+线段树/RMQ)
题目链接:点击查看 题目大意:给出 n 个数组成的数组 a ,再给出 m 次询问,每次询问需要回答区间 [ l , r ] 中所有元素的最小公倍数,强制在线 题目分析:首先考虑多个数的最小公倍数该如何 ...
- hdu 4391 Paint The Wall 线段树 +优化 2012 Multi-University Training Contest 10 )
http://acm.hdu.edu.cn/showproblem.php?pid=4391 题意: 刷墙, 以开始 有 n个节点,每个节点有一种颜色 ,m 次询问 m次 输入 a,l,r,z 如果 ...
最新文章
- HR与HRBP的区别
- IT民工创业之殇---续1
- 2020-09-11
- qt 设置按钮大小_Qt官方示例双向按钮
- mysql密码安全级别_Mysql数据库的安全性问题释疑
- javascript replace高级用法
- matlab时频分析工具箱安装_科研小班 | 加州大学伯克利分校 | 物理、电子工程:MATLAB信号和数据处理课题...
- TensorFlow:判断CUDA和GPU是否可用
- mysql数据类型范围导致失败
- Java实现冒泡排序及逆序冒泡排序
- linux文件目录类命令|--history指令
- Debug显示不支持opengl4,是双显卡未设置独立显卡模式
- 外星文明 未来计算机,科学家有望未来在地球“设计打印”外星生命
- 计算机u盘设备无法启动不了怎么办,u盘无法启动提示错误代码10该怎么处理
- 易语言跳出循环 c,易语言教程循环控制(到循环尾和跳出循环)
- nodejs html 生成图片,使用nodejs将html5 canvas base64编码图片保存为文件
- JS脚本油猴模拟输入失效问题
- DB2进行压缩的最佳实践
- rust tech trash是什么_“垃圾分类”用英语怎么说?
- navicat 阿里云 服务器 mysql_阿里云服务器优惠券领取 可以便宜购买阿里云服务器...