hdu 1754 I Hate It
来源:互联网 发布:淘宝一键开店 编辑:程序博客网 时间:2024/06/06 06:06
I Hate It
Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 29644 Accepted Submission(s): 11733
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。
在每个测试的第一行,有两个正整数 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 61 2 3 4 5Q 1 5U 3 6Q 3 4Q 4 5U 2 9Q 1 5
Sample Output
5659HintHuge input,the C function scanf() will work better than cin
线段树入门
#include <iostream>#include<stdio.h>#include<algorithm>#include<string.h>#include<queue>#include<vector>#include<stack>using namespace std;#define LL __int64#define N 200005struct node{ int l,r,mmax;}f[N*3];int a[N];void Creat(int t,int l,int r){ f[t].l=l; f[t].r=r; if(l==r) { f[t].mmax=a[l]; return ; } int tmp=t<<1,mid=(l+r)>>1; Creat(tmp,l,mid); Creat(tmp|1,mid+1,r); f[t].mmax=max(f[tmp].mmax,f[tmp|1].mmax);}int Query(int t,int l,int r){ if(f[t].l>=l&&f[t].r<=r) //当查询区间包含当前区间时 return f[t].mmax; //不必往下查询,直接返回最值 int tmp=t<<1,mid=(f[t].l+f[t].r)>>1; if(r<=mid) return Query(tmp,l,r); else if(l>mid) return Query(tmp|1,l,r); else return max(Query(tmp,l,mid),Query(tmp|1,mid+1,r));}void Union(int t,int x,int data){ if(f[t].l==f[t].r) { f[t].mmax=data; return ; } int tmp=t<<1,mid=(f[t].l+f[t].r)>>1; if(x<=mid) Union(tmp,x,data); else if(x>mid) Union(tmp|1,x,data); f[t].mmax=max(f[tmp].mmax,f[tmp|1].mmax);}int main(){ int i,n,m; char ch; int l,r,ans; while(~scanf("%d%d",&n,&m)) { for(i=1;i<=n;++i) { scanf("%d",&a[i]); } Creat(1,1,n); while(m--) { cin>>ch>>l>>r; if(ch=='Q') { ans=Query(1,l,r); cout<<ans<<endl; } else Union(1,l,r); } } return 0;}
- hdu 1754 I Hate It
- HDU 1754 I Hate It
- hdu 1754 I Hate It
- HDU 1754 I Hate It
- hdu 1754 I Hate It
- HDU 1754 I Hate It .
- HDU 1754 i hate it
- hdu 1754 I Hate It
- hdu 1754 I Hate It
- hdu 1754 I Hate It
- HDU 1754(I Hate It )
- hdu 1754 I Hate It
- hdu 1754 I Hate It
- HDU-1754-I Hate It
- hdu 1754 I Hate It
- hdu 1754 I Hate It
- hdu 1754 I hate it
- HDU 1754 I Hate It
- 二叉查找数C++ 数组模拟二叉树及面向对象实现
- linux:获取系统内存使用情况
- SQL数据库的常用操作
- merge
- 线性代数导论35——线性代数全总结
- hdu 1754 I Hate It
- Android高手进阶教程(十六)之---Android中万能的BaseAdapter(Spinner,ListView,GridView)的使用!
- Qt 编码 QObject::tr()
- Android高手进阶教程(十七)之---Android中Intent传递对象的两种方法(Serializable,Parcelable)!
- J.U.C之Lock
- ganglia3.6 监控 hadoop2.2.0
- Android中出现的一些BUG的解决方法
- mahout自带的例子 -------------------------分类
- 【Android】从主线程向子线程发消息