题目链接

线段树入门题,线段树单点更新求最大值问题。

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. #define m ((l+r)>>1)
  4. #define lson root<<1,l,m
  5. #define rson root<<1|1,m+1,r
  6. #define N 30005
  7. struct Tree
  8. {
  9. int l,r,ans;
  10. }tree[N<<];
  11. void build(int root,int l,int r)
  12. {
  13. tree[root].l=l;
  14. tree[root].r=r;
  15. if(l==r){
  16. scanf("%d",&tree[root].ans);
  17. return ;
  18. }
  19. build(lson);
  20. build(rson);
  21. tree[root].ans=max(tree[root<<].ans,tree[root<<|].ans);
  22. }
  23. void update(int root,int l,int r,int pos,int val)
  24. {
  25. if(l==r){
  26. tree[root].ans=val;
  27. return ;
  28. }
  29. if(pos<=m) update(lson,pos,val);
  30. if(pos>m) update(rson,pos,val);
  31. tree[root].ans=max(tree[root<<].ans,tree[root<<|].ans);
  32. }
  33. int query(int root,int l,int r,int ll,int rr)
  34. {
  35. //查询区间包含当前区间
  36. if(ll<=l&&rr>=r){
  37. return tree[root].ans;
  38. }
  39. int cnt=-;
  40. if(ll<=m)cnt=max(cnt,query(lson,ll,rr));
  41. if(rr>m) cnt=max(cnt,query(rson,ll,rr));
  42. return cnt;
  43. }
  44. int main()
  45. {
  46. int n,k;
  47. while(scanf("%d%d",&n,&k)!=EOF){
  48. build(,,n);
  49. int a,b;char c[];
  50. while(k--){
  51. scanf("%s%d%d",c,&a,&b);
  52. if(c[]=='U') update(,,n,a,b);
  53. else{
  54. if(a>b) swap(a,b);
  55. printf("%d\n",query(,,n,a,b));
  56. }
  57. }
  58. }
  59. return ;
  60. }

HDU 1754 I Hate It 线段树单点更新求最大值的更多相关文章

  1. HDU 1754 I Hate It 线段树 单点更新 区间最大值

    #include<iostream> #include<string> #include<algorithm> #include<cstdlib> #i ...

  2. HDU 1754 I Hate It 线段树(单点更新,成段查询)

    题目链接: hdu: http://acm.hdu.edu.cn/showproblem.php?pid=1754 题解: 单点更新,成段查询. 代码: #include<iostream> ...

  3. hdu 1754 I Hate It 线段树 单点更新 区间最值

    线段树功能:update:单点更新 query:区间最值 #include <bits/stdc++.h> #define lson l, m, rt<<1 #define r ...

  4. HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)

    HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...

  5. HDU.1394 Minimum Inversion Number (线段树 单点更新 区间求和 逆序对)

    HDU.1394 Minimum Inversion Number (线段树 单点更新 区间求和 逆序对) 题意分析 给出n个数的序列,a1,a2,a3--an,ai∈[0,n-1],求环序列中逆序对 ...

  6. HDU 1166 敌兵布阵(线段树单点更新,板子题)

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

  7. HDU 1166 敌兵布阵(线段树单点更新)

    敌兵布阵 单点更新和区间更新还是有一些区别的,应该注意! [题目链接]敌兵布阵 [题目类型]线段树单点更新 &题意: 第一行一个整数T,表示有T组数据. 每组数据第一行一个正整数N(N< ...

  8. HDU 1166 敌兵布阵(线段树单点更新,区间查询)

    描述 C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况 ...

  9. HDU 1754 I Hate It(线段树单点替换+区间最值)

    I Hate It [题目链接]I Hate It [题目类型]线段树单点替换+区间最值 &题意: 本题目包含多组测试,请处理到文件结束. 在每个测试的第一行,有两个正整数 N 和 M ( 0 ...

随机推荐

  1. position导致Safari工具栏不自动隐藏

    一般情况下,移动端网页在上滑的时候,Safari的工具栏会自动隐藏掉,下滑的时候又会出现. 但是,如果可滑动区域的最外层box写了position:absolute,就不会自动隐藏了. 例如像这样的页 ...

  2. Java防止SQL注入(转)

    一.SQL注入简介 SQL注入是比较常见的网络攻击方式之一,它不是利用操作系统的BUG来实现攻击,而是针对程序员编程时的疏忽,通过SQL语句,实现无帐号登录,甚至篡改数据库. 二.SQL注入攻击的总体 ...

  3. javaweb查看后台session和request所有的值

    遍历session @RequestMapping(value ="/test2") public String upload2( HttpSession session) { E ...

  4. winform总结3> 有趣的bat/winform程序完成自己的任务,然后把自己删除

    在winform的开发过程中往往会有这样的应用场景,执行完成某任务之后,程序需要把本身删除掉.比如卸载.分享一个比较简单实现. 思路就是利用批处理,关闭文件后执行bat,bat执行删除主文件,然后删除 ...

  5. struts-hibernate-ajax完成区县和街道级联下拉框功能

    前言:这次dao用的是hibernate,控制层和显示层用的是struts,页面用的是ajax... 啰嗦:我做这个用了很久,用了2周,难点没破解的地方,hibernate的多对一关系生成实体类中属性 ...

  6. 通过设置CSS属性让DIV水平居中

    通过设置CSS属性让DIV水平居中 ---------------------- <html> <head> <title></title> <m ...

  7. web网页中使用vlc插件播放相机rtsp流视频

    可参考: 使用vlc播放器做rtsp服务器 使用vlc播放器播放rtsp视频 使用vlc进行二次开发做自己的播放器 vlc功能还是很强大的,有很多的现成的二次开发接口,不需配置太多即可轻松做客户端播放 ...

  8. 跟我一起学习VIM

    跟我一起学习VIM - The Life Changing Editor   前两天同事让我在小组内部分享一下VIM,于是我花了一点时间写了个简短的教程.虽然准备有限,但分享过程中大家大多带着一种惊叹 ...

  9. metaWeblog Test

     #include "stdio.h" int main(int argc ,char **argv) { printf("argc = %d \n",arg ...

  10. Oracle to_date()函数的用法

    Oracle to_date()函数的用法 to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,供您参考学习. 在Orac ...