热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HDU1754IHateIt(线段树:单点替换求最值)

IHateItTimeLimit:90003000MS(JavaOthers)MemoryLimit:3276832768K(JavaOthers)TotalSubmission

I Hate It
Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 66254    Accepted Submission(s): 25769


Problem Description

很多学校流行一种比较的习惯。老师们很喜欢询问,从某某到某某当中,分数最高的是多少。
这让很多学生很反感。
不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问。当然,老师有时候需要更新某位同学的成绩。


Input

本题目包含多组测试,请处理到文件结束。
在每个测试的第一行,有两个正整数 N 和 M ( 0 学生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

2007省赛集训队练习赛(6)_linle专场

Recommend

lcy   |   We have carefully selected several similar problems for you:  1542 2795 1540 1255 1828 

题意:略。

题解:线段树单点替换求最值。




AC代码:

#pragma comment(linker, "/STACK:102400000,102400000")
//#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair pii;
typedef vector vi;
const double eps = 1e-8;
const int INF = 1e9+7;
const ll inf &#61;(1LL<<62) ;
const int MOD &#61; 1e9 &#43; 7;
const ll mod &#61; (1LL<<32);
const int N &#61;1e6&#43;6;
const int M&#61;100010;
const int maxn&#61;200010;
#define mst(a) memset(a, 0, sizeof(a))
#define M_P(x,y) make_pair(x,y)
#define in freopen("in.txt","r",stdin)
#define rep(i,j,k) for (int i &#61; j; i <&#61; k; i&#43;&#43;)
#define per(i,j,k) for (int i &#61; j; i >&#61; k; i--)
#define lson l , mid , rt <<1
#define rson mid &#43; 1 , r , rt <<1 | 1
const int lowbit(int x) { return x&-x; }
//const int lowbit(int x) { return ((x)&((x)^((x)-1))); }
int read(){ int v &#61; 0, f &#61; 1;char c &#61;getchar();
while( c <48 || 57 while(48 <&#61; c && c <&#61; 57) v &#61; v*10&#43;c-48, c &#61; getchar();
return v*f;}
int MAX[maxn<<2];void pushup(int rt) //把当前结点的信息更新到父结点
{//线段树是用数组来模拟树形结构//对于每一个节点rt,左子节点为 2*rt (一般写作rt<<1)右子节点为 2*rt&#43;1&#xff08;一般写作rt<<1|1&#xff09; MAX[rt] &#61; max(MAX[rt<<1] , MAX[rt<<1|1]);
}
void build(int l,int r,int rt)
{if(l&#61;&#61;r){scanf("%d",&MAX[rt]); return;}int mid&#61;(l&#43;r)>>1;build(lson);//递归构造左子树build(rson);//递归构造右子树pushup(rt); //更新求和
}
void update(int p, int change, int l, int r, int rt)//单点替换
{if(l&#61;&#61;r){MAX[rt] &#61; change; return ;}int mid&#61;(l&#43;r) >> 1;if(p<&#61;mid) update(p,change,lson);else update(p,change,rson);pushup(rt);
}
int query(int L,int R,int l,int r,int rt) //区间最值
{if(L <&#61; l && r <&#61; R){return MAX[rt];}int mid &#61; (l&#43;r)>>1;int ans &#61; 0;if(L <&#61; mid) ans&#61;max(ans,query(L,R,lson));if(R > mid) ans&#61;max(ans,query(L,R,rson));return ans;
}
int main()
{int n,m;while(~scanf("%d%d",&n,&m)){build(1,n,1);while(m--){char op[3];int a,b;scanf("%s%d%d",op,&a,&b);if(op[0]&#61;&#61;&#39;Q&#39;)printf("%d\n",query(a,b,1,n,1));else update(a,b,1,n,1);}}return 0;
}




推荐阅读
  • 本文基于刘洪波老师的《英文词根词缀精讲》,深入探讨了多个重要词根词缀的起源及其相关词汇,帮助读者更好地理解和记忆英语单词。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • golang常用库:配置文件解析库/管理工具viper使用
    golang常用库:配置文件解析库管理工具-viper使用-一、viper简介viper配置管理解析库,是由大神SteveFrancia开发,他在google领导着golang的 ... [详细]
  • [论文笔记] Crowdsourcing Translation: Professional Quality from Non-Professionals (ACL, 2011)
    Time:4hoursTimespan:Apr15–May3,2012OmarZaidan,ChrisCallison-Burch:CrowdsourcingTra ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
author-avatar
哈罗xeh_406
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有