I hate it
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
给定N个按一定顺序排列的值,对这N个值进行两种操作:
1、查询某个区间[A,B]的最大值;
2、修改序号为A处的值;
代码如下:
#include "stdio.h"
#include <cstdio>
#include <climits> using namespace std; #define M ((L+R)>>1)
#define lson rt<<1,L,M
#define rson rt<<1|1,M+1,R
#define root 1,1,N
#define max(a,b) ((a>b)?a:b) const int maxn = 200001; int maxv[maxn << 2],ql,qr,tar,v,val[maxn]; inline void pushup(int rt)
{
maxv[rt] = max(maxv[rt<<1],maxv[rt<<1|1]);
} void build(int rt,int L,int R)
{
if(L == R) maxv[rt] = val[L];
else
{
build(lson); build(rson);
pushup(rt);
}
} void update(int rt,int L,int R)
{
if(L == R) maxv[rt] = v;
else { if(tar <= M) update(lson);
if(tar > M) update(rson);
pushup(rt);
}
} int query(int rt,int L,int R)
{
if(ql <= L && qr >= R) return maxv[rt];
int lv = -INT_MAX,rv = -INT_MAX;
if(ql <= M) lv = query(lson);
if(qr > M) rv = query(rson);
return max(lv,rv);
} int main()
{
int N,m;
char cmd;
while(~scanf("%d%d",&N,&m))
{
for(int i = 1;i <= N;i++)
scanf("%d",val + i);
build(root);
for(int i = 1;i <= m;i++)
{
scanf(" %c",&cmd);
if(cmd == 'Q')
{
scanf("%d%d",&ql,&qr);
printf("%d\n",query(root));
}
else
{
scanf("%d%d",&tar,&v);
update(root);
}
}
}
return 0;
}
随机推荐
- python模块介绍- SocketServer 网络服务框架
来源:https://my.oschina.net/u/1433482/blog/190612 摘要: SocketServer简化了网络服务器的编写.它有4个类:TCPServer,UDPServe ...
- 《Linux内核分析》课程总结
朱宇轲 + 原创作品转载请注明出处 + <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 不知不觉,在网易 ...
- 分析Tornado的协程实现
转自:http://www.binss.me/blog/analyse-the-implement-of-coroutine-in-tornado/ 什么是协程 以下是Wiki的定义: Corouti ...
- mac配置impala odbc
下载mac对应驱动并安装:http://www.cloudera.com/downloads.html.html *HOST 地址是impala Daemon所在的机器ip,端口可以在cm中设置 vi ...
- Change the Windows 7 Taskbar Thumbnail and List Mode
Manually in Registry Editor 1. Open the Start Menu, then type regedit in the search boxand press Ent ...
- 修改安全策略组 -- windows
1.新建安全策略组文件SAMTool.inf md C:\SAMLog & echo [Version] >C:\SAMLog\SAMTool.inf &echo signatu ...
- Tomcat从内存、并发、缓存方面优化方法
Tomcat有很多方面,从内存.并发.缓存四个方面介绍优化方法. 一.Tomcat内存优化 Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚本 cata ...
- jquery的.submit
$("form").submit(function(e){ alert("Submitted"); });
- 关于学习是UIWebView的一些思考
前几天因为数据中加载有html语言的数据,关于html语言和UIWebView,有一些纠结,经过几天的研究,也有了一些自己的简单的见解. 我有两个页面需要加载html语言(注意,这里 ...
- php json_encode中文unicode问题
php调用json_encode将中文字符串存入mysql后读取出来有问题,发现存进去的时候把'\'给去掉了.解决方法是调用json_encode时候后面加JSON_UNESCAPED_UNICODE ...