I Hate It

Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 33726    Accepted Submission(s): 13266

Problem 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

Huge input,the C function scanf() will work better than cin

 
Author
linle
 
Source
 
Recommend
lcy   |   We have carefully selected several similar problems for you:  1698 1542 1394 2795 1540 

 
  线段树,入门题
  题意:这是范围最大值问题(RMQ),求出某区间范围内的最大值。
  思路:更新,改变递归过程中所有值比他小的节点;查询,找到区间,输出区间的值。
  注意:数组要开的足够,不然会RE(一般开到N的三倍)。另外注意处理每一条询问后回车符,否则也会RE。
  用线段树速度很慢,虽然AC了,但是用了2000MS,不晓得那些几百MS AC的大神代码是怎么写的,膜拜。
  代码:
 #include <stdio.h>
#define MAXSIZE 200000
struct Node{
int left,right;
int n;
};
Node a[MAXSIZE*+];
void Init(Node a[],int L,int R,int d) //初始化线段树
{
if(L==R){ //当前节点没有儿子节点,即递归到叶子节点。递归出口
a[d].left = L;
a[d].right = R;
a[d].n = ;
return ;
} int mid = (L+R)/; //初始化当前节点
a[d].left = L;
a[d].right = R;
a[d].n = ; Init(a,L,mid,d*); //递归初始化当前节点的儿子节点
Init(a,mid+,R,d*+); }
void Update(Node a[],int L,int R,int d,int x) //对区间[L,R]插入值x,从节点d开始更新。
{
if(L==a[d].left && R==a[d].right){ //插入的区间匹配,则直接修改该区间值
a[d].n = x;
return ;
}
if(x>a[d].n) //沿路节点比该值小的都重新赋值
a[d].n = x;
int mid = (a[d].left + a[d].right)/;
if(R<=mid){ //中点在右边界R的右边,则应该插入到左儿子
Update(a,L,R,d*,x);
}
else if(mid<L){ //中点在左边界L的左边,则应该插入到右儿子
Update(a,L,R,d*+,x);
}
else { //否则,中点在待插入区间的中间
Update(a,L,mid,d*,x);
Update(a,mid+,R,d*+,x);
}
}
int Query(Node a[],int L,int R,int d) //查询区间[L,R]的值,从节点d开始查询
{
if(L==a[d].left && R==a[d].right){ //查找到区间,则直接返回该区间值
return a[d].n;
}
int mid = (a[d].left + a[d].right)/;
if(R<=mid){ //中点在右边界R的右边,则应该查询左儿子
return Query(a,L,R,d*);
}
else if(mid<L){ //中点在左边界L的左边,则应该查询右儿子
return Query(a,L,R,d*+);
}
else { //中点在待查询区间的中间,左右孩子都查找
int A = Query(a,L,mid,d*);
int B = Query(a,mid+,R,d*+);
return A>B?A:B;
}
}
int main()
{
int i,n,m,A,B;
char c;
while(scanf("%d%d",&n,&m)!=EOF){
Init(a,,n,); //初始化 for(i=;i<=n;i++){ //输入
int t;
scanf("%d",&t);
Update(a,i,i,,t);
} for(i=;i<=m;i++){ //m次查询
scanf("%*"); //读掉空格
scanf("%c%d%d",&c,&A,&B);
switch(c){
case 'Q':
printf("%d\n",Query(a,A,B,));
break;
case 'U':
Update(a,A,A,,B);
break;
default:break;
}
}
}
return ;
}

Freecode : www.cnblogs.com/yym2013

hdu 1754:I Hate It(线段树,入门题,RMQ问题)的更多相关文章

  1. hdu 1754 I Hate It 线段树基础题

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

  2. hdu 1754 I Hate It(线段树水题)

    >>点击进入原题测试<< 思路:线段树水题,可以手敲 #include<string> #include<iostream> #include<a ...

  3. hdu 1166敌兵布阵(线段树入门题)

    >>点击进入原题测试<< 思路:这两天在学线段树,这个题直接手敲一下线段树就行了,都没有用上懒人标记.入门题 cin,cout会超时,记得加std::ios::sync_wit ...

  4. HDU 1754 I Hate It(线段树模板题)

    题目链接: 传送门 I Hate It Time Limit: 3000MS     Memory Limit: 32768 K Description 很多学校流行一种比较的习惯.老师们很喜欢询问, ...

  5. hdu 1754 I Hate It 线段树 点改动

    // hdu 1754 I Hate It 线段树 点改动 // // 不多说,裸的点改动 // // 继续练 #include <algorithm> #include <bits ...

  6. HDU 1754 I Hate It 线段树单点更新求最大值

    题目链接 线段树入门题,线段树单点更新求最大值问题. #include <iostream> #include <cstdio> #include <cmath> ...

  7. HDU 1754 I Hate It(线段树之单点更新,区间最值)

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  8. 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=175 ...

  9. HDU 1754 I Hate It(线段树单点替换+区间最值)

    I Hate It [题目链接]I Hate It [题目类型]线段树单点替换+区间最值 &题意: 本题目包含多组测试,请处理到文件结束. 在每个测试的第一行,有两个正整数 N 和 M ( 0 ...

  10. HDU 1754 I Hate It (线段树)

    题意:略. 析:裸的线段树. 代码如下: #pragma comment(linker, "/STACK:1024000000,1024000000") #include < ...

随机推荐

  1. Panabit安装配置笔记

    最近研究了linux下基于FREEBSD的开源流控软件Panabit,感觉功能还不错,单位公司如果经费不足的朋友需要做内网流控可以使用这款软件,最新免费版ISO镜像仅支持网桥模式和旁路模式,256个并 ...

  2. 2 GPS utility methods

    Methond 1 is to check whether the GPS is on: 1 2 3 4 5 public boolean isGPSIsOn() { LocationManager ...

  3. bootstrap框架----像素

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. 应用HTK搭建语音拨号系统4: 识别器评估

    选自:http://maotong.blog.hexun.com/6261890_d.html 苏统华 哈尔滨工业大学人工智能研究室 2006年10月30日 声明:版权所有,转载请注明作者和来源 该系 ...

  5. 【GoLang】golang 面向对象编程 & 面向接口编程

    005.面向对象&接口编程 1 面向函数编程 1.1 将数据作为参数传递到函数入参 1.2 对象与函数是分离的 2 面向对象编程 2.1 使用者看起来函数作为对象的属性而非参数 2.2 函数属 ...

  6. ios UIButton 选中后背景图片变化发灰问题

    UIButton的类型如果选择了System类型,那么设置背景图后,点击的效果是图片发灰,而不是默认的那种图片变淡黑色效果,需要用customer类型就好了.

  7. Kafka集群环境搭建

    Kafka是一个分布式.可分区.可复制的消息系统.Kafka将消息以topic为单位进行归纳:Kafka发布消息的程序称为producer,也叫生产者:Kafka预订topics并消费消息的程序称为c ...

  8. 设置UISegmentedControl的字体大小和颜色

    NSDictionary *dic = [NSDictionarydictionaryWithObjectsAndKeys:[UIColorblackColor],UITextAttributeTex ...

  9. codeforces 499B.Lecture 解题报告

    题目链接:http://codeforces.com/problemset/problem/499/B 题目意思:给出两种语言下 m 个单词表(word1, word2)的一一对应,以及 profes ...

  10. Mysql 基础 高级查询

    在西面内容中    car  和  nation   都表示 表名 1.无论 高级查询还是简单查询   都用  select.. from..语句   from  后面 加表名  可以使一张表也可以是 ...