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

5 6 5 9

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相关推荐

  1. HDU 1754 I Hate It 线段树

    I Hate It Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老师的要 ...

  2. HDU 1166 敌兵布阵(线段树:点更新,区间求和)

    HDU 1166 敌兵布阵(线段树:点更新,区间求和) http://acm.hdu.edu.cn/showproblem.php?pid=1166 题意: 给你n个整数,然后给你多条命令,每条命令如 ...

  3. HDU 3016 Man Down (线段树+dp)

    HDU 3016 Man Down (线段树+dp) Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Ja ...

  4. 2019CCPC网络赛 1002 HDU 6703(权值线段树)

    2019CCPC网络赛 1002 HDU 6703(权值线段树) 思路:用权值线段树存题目给的数据后,2操作就是求权值线段树中大于等于k的部分中,靠近左端点的第一个大于r的值(这个求出来的只是原序列中 ...

  5. 【HDU - 5875】Function(线段树,区间第一个小于某个数的数 或 RMQ二分)

    题干: The shorter, the simpler. With this problem, you should be convinced of this truth.        You a ...

  6. HDU 6070 Dirt Ratio(线段树、二分)

    http://acm.hdu.edu.cn/showproblem.php?pid=6070 题解 首先不难看出错误率是单调的,那么我们可以直接二分答案x,某个区间的错误率=区间数的种类cnt/区间长 ...

  7. hdu 5692 Snacks(dfs序+线段树区间更新)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5692 解题思路:这道题是树节点的点权更新,而且涉及到子树,常用的思路是利用dfs序,用线段树来对区间进 ...

  8. HDU 6089 Rikka with Terrorist (线段树)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=6089 题解 这波强行维护搞得我很懵逼... 扫描线,只考虑每个点能走到左上方(不包括正上方,但包括正左 ...

  9. CodeForces - 1422F Boring Queries(主席树+线段树/RMQ)

    题目链接:点击查看 题目大意:给出 n 个数组成的数组 a ,再给出 m 次询问,每次询问需要回答区间 [ l , r ] 中所有元素的最小公倍数,强制在线 题目分析:首先考虑多个数的最小公倍数该如何 ...

  10. 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 如果 ...

最新文章

  1. HR与HRBP的区别
  2. IT民工创业之殇---续1
  3. 2020-09-11
  4. qt 设置按钮大小_Qt官方示例双向按钮
  5. mysql密码安全级别_Mysql数据库的安全性问题释疑
  6. javascript replace高级用法
  7. matlab时频分析工具箱安装_科研小班 | 加州大学伯克利分校 | 物理、电子工程:MATLAB信号和数据处理课题...
  8. TensorFlow:判断CUDA和GPU是否可用
  9. mysql数据类型范围导致失败
  10. Java实现冒泡排序及逆序冒泡排序
  11. linux文件目录类命令|--history指令
  12. Debug显示不支持opengl4,是双显卡未设置独立显卡模式
  13. 外星文明 未来计算机,科学家有望未来在地球“设计打印”外星生命
  14. 计算机u盘设备无法启动不了怎么办,u盘无法启动提示错误代码10该怎么处理
  15. 易语言跳出循环 c,易语言教程循环控制(到循环尾和跳出循环)
  16. nodejs html 生成图片,使用nodejs将html5 canvas base64编码图片保存为文件
  17. JS脚本油猴模拟输入失效问题
  18. DB2进行压缩的最佳实践
  19. rust tech trash是什么_“垃圾分类”用英语怎么说?
  20. navicat 阿里云 服务器 mysql_阿里云服务器优惠券领取 可以便宜购买阿里云服务器...

热门文章

  1. 【HDU】4391 Paint The Wall
  2. 对象池 IObjectPool -- ESBasic 可复用的.NET类库(15)
  3. C# aspx 数据绑定集中(待修改)
  4. 易语言-数据类型及其长度
  5. k8s踩坑记第2篇--3个IP折磨人的故事
  6. echarts中的option.legend.data has not been defined.
  7. 关于大学生阶段团队类型选择
  8. 544B. Sea and Islands
  9. 机器学习傻瓜的深入研究
  10. 【转载】著名黑客雷蒙评价几种编程语言