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 ...
随机推荐
- 外文翻译 《How we decide》赛场上的四分卫 第四节
这是第一章的最后一节. 书的导言 本章第一节 本章第二节 本章第三节 制作肥皂剧是非常不易的.整个制作组都要很紧张的工作,每天都要拍摄一些新的事件.新的大转折的剧情需要被想象出来,新的剧本需要被编写, ...
- WPF学习09:数据绑定之 Binding to List Data
从WPF学习03:Element Binding我们可以实现控件属性与控件属性的绑定. 从WPF学习07:MVVM 预备知识之数据绑定 我们可以实现控件属性与自定义对象属性的绑定. 而以上两个功能在实 ...
- AJPFX解析Java关键字之assert
Java有许多关键字,但是这个关键字估计很少有人了解,今天就跟大家谈一谈这个关键字吧. 先说明一下,这个关键字开发中用的极少,感兴趣的朋友可以了解一下. 一.概述 在C和C++语言中都有assert关 ...
- JDK11源码分析之集合类(一)----HashMap
一,首先需要拉取JDK11源码: 方便起见我给出芋道源码作者已经拉取好的openJDK11的GitHub地址只需要fork一下克隆到本地导入IDEA中就可以对源码分析了: https://github ...
- Python3 动手自己写谷歌翻译
本篇为实现谷歌翻译的功能,在编写的时候以为只是一个接口的问题. 没想到的是每次翻译都会触发一次JS的执行,在请求参数中生成一个tk. 文中tk的实现是复用的网上大神的代码生成tk. 好了,不说了直接看 ...
- git ---查看工作状态和历史提交
1.git查看状态 -git status 2.版权声明 版权声明:新建一个 LICENSE.txt 文件 开源协议:MIT //开源许可里面的最宽松的一个协议,别人可以随便用你的代码,但 ...
- JAVA一些错误代码
//算术异常 ArithmeticExecption //空指针异常类 NullPointerException //类型强制转换异常 ClassCastException //数组负下标异常 Neg ...
- iOS---UICollectionView自定义流布局实现瀑布流效果
自定义布局,实现瀑布流效果 自定义流水布局,继承UICollectionViewLayout 实现一下方法 // 每次布局之前的准备 - (void)prepareLayout; // 返回所有的尺寸 ...
- hexo_config.yml配置内容
# Hexo Configuration ## Docs: https://hexo.io/docs/configuration.html ## Source: https://github.com/ ...
- jsencrypt加解密 &&cryptico
npm install --save jsencrypt import {JSEncrypt} from 'jsencrypt'; //导入公钥if ( publicKey.indexOf('---- ...