I Hate It

                                                                                                        Time Limit: 9000/3000 MS
(Java/Others)                                                                                              

                                                                                                       Memory Limit: 32768/32768
K (Java/Others)                                                                                                                                                                                                             

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

只能怪自己知识算法掌握得不够,开始用线段数做,看起来和敌兵布阵一样,但一个CE一个RE,绝望啊,看起来一样,而且运行也没有错,趁着吃饭的时间又打了遍,AC~~~再看看以前的代码,然后就明白了自己的不足--没有虚心潜心学习,明白了一点就沾沾自喜,以为自己掌握了,结果.................

CE代码:

#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<cmath>
using namespace std;
const int N=200000+50;
struct node
{
int l,r,n;
}a[N<<2];
int max(int a,int b)
{
return a>b?a:b;
}
void build(int l,int r,int k)
{
int mid;
if(l==r)
{
a[k].l=a[k].r=l;
a[k].n=0;
return ;
}
mid=(l+r)/2;
a[k].l=l,a[k].r=r;
build(l,mid,2*k);
build(mid+1,r,2*k+1);
}
void insert(int n,int d,int k)
{
int mid;
if(a[k].l==a[k].r&&a[k].r==d)
{
a[k].n+=n;
return ;
}
mid=(a[k].l+a[k].r)/2;
if(d<=mid) insert(n,d,2*k);
else insert(n,d,2*k+1);
a[k].n=max(a[k*2].n,a[k*2+1].n);
}
void xiugai(int n,int d,int k)
{
int mid;
if(a[k].l==a[k].r&&a[k].r==d)
{
a[k].n=n;
return ;
}
mid=(a[k].l+a[k].r)/2;
if(d<=mid) xiugai(n,d,2*k);
else xiugai(n,d,2*k+1);
a[k].n=max(a[k*2].n,a[k*2+1].n);
}
int maxx;
void query(int l,int r,int k)
{
int mid;
if(a[k].l==l&&a[k].r==r)
{
maxx=max(maxx,a[k].n);
return ;
}
mid=(a[k].l+a[k].r)/2;
if(r<=mid) query(l,r,2*k);
else if(l>mid) query(l,r,2*k+1);
else
{
query(l,mid,2*k);
query(mid+1,r,2*k+1);
}
}
int main()
{
int t,n,m,i;
char c;
while(~scanf("%d%d",&n,&t))
{ build(1,n,1);
for(i=1;i<=n;i++)
{
scanf("%d",&m);
insert(m,i,1);
}
int a,b;
while(scanf("%c",&c))
{
maxx=0;
scanf("%d%d",&a,&b);
if(c=='Q')
{
query(a,b,1);
printf("%d\n",maxx);
}
else if(c=='U')
{
xiugai(b,a,1);
}
}
}
return 0;
}

与下面的AC代码就可以明显看出区别了:

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<cmath>
using namespace std;
const int N=200000+10;
struct node
{
int l,r,n;
} a[N<<2];
void build(int l,int r,int k)
{
int mid;
if(l==r)
{
a[k].l=a[k].r=l;
a[k].n=0;
return ;
}
mid=(l+r)/2;
a[k].l=l,a[k].r=r;
build(l,mid,2*k),build(mid+1,r,2*k+1);
}
void update(int d,int n,int k)
{
int mid;
if(a[k].l==a[k].r&&a[k].l==d)
{
a[k].n=n;
return ;
}
mid=(a[k].l+a[k].r)/2;
if(d<=mid) update(d,n,2*k);
else if(d>mid) update(d,n,2*k+1);
a[k].n=max(a[k*2].n,a[k*2+1].n);
}
int maxn;
void query(int l,int r,int k)
{
int mid;
if(a[k].l==l&&a[k].r==r)
{
maxn=max(a[k].n,maxn);
return ;
}
mid=(a[k].l+a[k].r)/2;
if(r<=mid) query(l,r,2*k);
else if(l>mid) query(l,r,2*k+1);
else
{
query(l,mid,2*k);
query(mid+1,r,2*k+1);
}
}
int main()
{
int n,m,x,i;
char s;
while(~scanf("%d%d",&n,&m))
{
memset(a,0,sizeof(a));
build(1,n,1);
for(i=1; i<=n; i++)
{
scanf("%d",&x);
update(i,x,1);
}
int a,b;
while(m--)
{
getchar();
scanf("%c%d%d",&s,&a,&b);
if(s=='U')
update(a,b,1);
else
{
maxn=0;
query(a,b,1);
printf("%d\n",maxn);
}
}
}
return 0;
}

都是出自自己的手,只不过创作时间不同,然而熟练与否一眼便可知晓;

HDU1754-I Hate It,线段数水题~~2016.4.11的更多相关文章

  1. POJ 3468 A Simple Problem with Integers(线段树水题)

    A Simple Problem with Integers Time Limit: 5000MS   Memory Limit: 131072K Total Submissions: 135904 ...

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

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

  3. HDU1166-敌兵布阵,线段数模板题~~

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  4. 【wikioi】1191 数轴染色(线段树+水题)

    http://wikioi.com/problem/1191/ 太水的线段树了,敲了10分钟就敲完了,但是听说还有一种并查集的做法?不明觉厉. #include <cstdio> #inc ...

  5. codeforces 339C Xenia and Bit Operations(线段树水题)

    转载请注明出处: http://www.cnblogs.com/fraud/          ——by fraud Xenia and Bit Operations Xenia the beginn ...

  6. P1198 最大数 线段树水题

    这道题模拟一下可以过,但是我们发现线段树也可以安全水过...... 写的线段树只需要滋磁单点修改,区间求max即可 我一开始犯了一个很SB的错误:每次插入修改了t,然后疯狂爆0到怀疑人生... 而且我 ...

  7. hdu - 1394 Minimum Inversion Number(线段树水题)

    http://acm.hdu.edu.cn/showproblem.php?pid=1394 很基础的线段树. 先查询在更新,如果后面的数比前面的数小肯定会查询到前面已经更新过的值,这时候返回的sum ...

  8. hdu 1999 不可摸数 水题。

    不可摸数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  9. CCF 201312-1 出现次数最多的数 (水题)

    问题描述 给定n个正整数,找出它们中出现次数最多的数.如果这样的数有多个,请输出其中最小的一个. 输入格式 输入的第一行只有一个正整数n(1 ≤ n ≤ 1000),表示数字的个数. 输入的第二行有n ...

随机推荐

  1. Hash环/一致性Hash原理

    当前,Memcached.Redis这类分布式kv缓存已经非常普遍.从本篇开始,本系列将分析分布式缓存相关的原理.使用策略和最佳实践. 我们知道Memcached的分布式其实是一种“伪分布式”,也就是 ...

  2. solr facet查询及solrj 读取facet数据[转]

    solr facet查询及solrj 读取facet数据 | 所属分类:solr facet solrj 一.   Facet 简介 Facet 是 solr 的高级搜索功能之一 , 可以给用户提供更 ...

  3. 为localhost添加https

    1.按照https://stackoverflow.com/a/7184031/4619958来做 其中,CommonName填写localhost 2.在ssl.conf里头加上 <Direc ...

  4. SecureCRT中vi或vim编辑器显示中文乱码问题

    vi ~/.vimrc  //新建文件 syntax on set showmode set autowrite set number set encoding=utf-8 fileencodings ...

  5. Android虚拟机电池状态设置

    问题描述: 安装SDK后使用AVD配合APPIUM进行测试,此时虚拟机的电池状态为0%充电中:部分APP会对手机电池状态有要求,不符合要求时,无法安装或打开. 解决思路: 1.Android系统设置( ...

  6. RHEL5.8上SAMBA源码修改打包安装流程

    之前一直使用系统自带的SAMBA,近期需要对SAMBA代码做一些修改,然后还是打算用RPM包的方式来安装部署. 这个流程本身不复杂,在这里记录下来,免得在另外写说明文档. 关键词:RHEL5.8, s ...

  7. 如何在Ubuntu里安装Helm

    Helm是什么?在战网上玩过暗黑破坏神2代的程序员们应该还记得,Helm是国度的意思. 而在计算机领域,Helm是什么? Helm是Kubernetes的一个包管理工具,有点像nodejs的npm,U ...

  8. 使用Eclipse进行PHP的服务器端调试

    最近工作需要对PHP的服务器端代码进行远程调试,涉及到Eclipse里环境的设置.在网上找了很多资料,大多不全,或者缺少配图,于是把自己做的过程中遇到的问题记录了下来,希望对需要的朋友们有所帮助. 首 ...

  9. Architecture:架构 元素与关系

    http://www.iso-architecture.org/42010/cm/ Systems have architectures. In the Standard, the architect ...

  10. elasticsearch时间格式DateFormat的含义

    时间格式 枚举(或者英文)format pattern 含义 custom - 自定义属性 none - 不转化 basic_date yyyyMMdd 基本时间 basic_date_time   ...