HDU 1754_I Hate It
【题意】给定区间求最大值
【分析】线段树单点更新
【代码】
#include<cstdio>
#include<iostream>
using namespace std;
const int maxn=1<<21;
const int INF=0x3fffffff;
int Max=0;
int mid;
struct Node
{
int l,r;//左孩子,右孩子
int value;
}N[maxn];
int p[200005];//记录标号
void build(int i,int left ,int right)//区间[left,right],节点标号i
{
N[i].l=left;
N[i].r=right;
N[i].value=0;
if(left==right)
{
p[left]=i;
return;
}
mid=(left+right)>>1;
build(i<<1,left,mid);
build(1+(i<<1),mid+1,right);
}
void update(int i)//从下往上更新单节点
{
if(i==1) return ;
int pi=i/2;
int left=pi<<1;
int right=(pi<<1)+1;
N[pi].value=max(N[left].value,N[right].value);
update(i/2);
}
void query(int i,int left,int right)//从上往下查询节点
{
if(N[i].l==left&&N[i].r==right)
{
Max=max(N[i].value,Max);
return;
}
i<<=1;
if(N[i].r>=left&&N[i].r>=right) query(i,left,right);
else if(N[i].r>=left&&N[i].r<=right) query(i,left,N[i].r);
i++;
if(N[i].l<=right&&N[i].l<=left) query(i,left,right);
else if(N[i].l<=right&&N[i].l>=left) query(i,N[i].l,right);
}
int main (void)
{
int n,m;
int A,B;
char c[2];
while(scanf("%d%d",&n,&m)==2)
{
build(1,1,n);
for(int i=1;i<=n;i++)
{
scanf("%d",& N[p[i]].value);
update(p[i]);
}
for(int i=1;i<=m;i++)
{
scanf("%s%d%d",c,&A,&B);
if(c[0]=='Q')
{
Max=0;
query(1,A,B);
printf("%d\n",Max);
}
else
{
N[p[A]].value=B;
update(p[A]);
}
}
}
return 0;
}
HDU 1754_I Hate It的更多相关文章
- HDOJ 2111. Saving HDU 贪心 结构体排序
Saving HDU Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- 【HDU 3037】Saving Beans Lucas定理模板
http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ...
- hdu 4859 海岸线 Bestcoder Round 1
http://acm.hdu.edu.cn/showproblem.php?pid=4859 题目大意: 在一个矩形周围都是海,这个矩形中有陆地,深海和浅海.浅海是可以填成陆地的. 求最多有多少条方格 ...
- HDU 4569 Special equations(取模)
Special equations Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
- HDU 4006The kth great number(K大数 +小顶堆)
The kth great number Time Limit:1000MS Memory Limit:65768KB 64bit IO Format:%I64d & %I64 ...
- HDU 1796How many integers can you find(容斥原理)
How many integers can you find Time Limit:5000MS Memory Limit:32768KB 64bit IO Format:%I64d ...
- hdu 4481 Time travel(高斯求期望)(转)
(转)http://blog.csdn.net/u013081425/article/details/39240021 http://acm.hdu.edu.cn/showproblem.php?pi ...
- HDU 3791二叉搜索树解题(解题报告)
1.题目地址: http://acm.hdu.edu.cn/showproblem.php?pid=3791 2.参考解题 http://blog.csdn.net/u013447865/articl ...
- hdu 4329
problem:http://acm.hdu.edu.cn/showproblem.php?pid=4329 题意:模拟 a. p(r)= R'/i rel(r)=(1||0) R ...
随机推荐
- 不支持正在使用的 .Net 组帧模式。有关详细信息,请参阅服务器日志--解决方案
问题在于 NetTcpBinding 服务端和客户端配置不一致. 至少 客户端和服务端:安全性.是否启用可靠会话以及传输方式必须一致 主要是传输方式导致 "不支持正在使用的 .Net 组帧 ...
- CSS ul li a 背景图片与文字对齐
<div class="four"> <h2>电子商务</h2> <img src="images/photo2.gif&quo ...
- 自学 iOS - 三十天三十个 Swift 项目 第二天
继续做仿造着别人的第二个 1.首先下载 一些字体 网上搜索 "造字工房" 2.把下载的相应字体文件放到工程之中,就Ok了 不多说 效果如下 可以下面这个方法 检索项目里面所有的字体 ...
- 浏览器和ES5的介绍
浏览器的组成 : shell(浏览器的外壳).内核(渲染引擎.js引擎)主流浏览器及其内核: IE tritent(IE9及以下,IE10及以上用webkit) ...
- javax.xml.bind.UnmarshalException: 意外的元素 (uri:"", local:"xml")。所需元素为(none)
将xml转换为object时候报错:javax.xml.bind.UnmarshalException: 意外的元素 (uri:"", local:"xml") ...
- 唤醒键盘时取消对特定类的position:fixed定位
/* 唤起键盘时取消对特定类的position:fixed定位 */ var windheight = $(window).height(); /*未唤起键盘时当前窗口高度*/ $(window).r ...
- nginx php 配置模板
server { listen 80; server_name www.xxx.com; #access_log logs/www.xxx.com.access. ...
- springMVC返回Base64位编码图片验证码
import java.awt.Color;import java.awt.Font;import java.awt.Graphics;import java.awt.Graphics2D;impor ...
- Maven error in eclipse (pom.xml) : Failure to transfer org.apache.maven.plugins:maven-surefire-plugin:pom:2.12.4
i wanna make web project using the Maven to import automatically all libraries that i need, so i cho ...
- 引用类型 (Reference Type Matters)、扩展与派发方式
引用类型 (Reference Type Matters) 引用的类型决定了派发的方式. 这很显而易见, 但也是决定性的差异. 一个比较常见的疑惑, 发生在一个协议拓展和类型拓展同时实现了同一个函数的 ...