思路:与我发表的上一遍求和的思想一样   仅仅是如今变成求最大值而已

AC代码:

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cmath>
  4. #include<cstring>
  5. #include<algorithm>
  6. using namespace std;
  7. inline int Max(int a, int b)
  8. {
  9. return a > b ? a : b;
  10. }
  11. const int MAXN = 200001; // 区间范围
  12. struct
  13. {
  14. int l, r, m; // l 左端点,r 右端点。m 为该区间的最大分数
  15. } tree[MAXN*4];
  16. int a[MAXN];
  17. void creat(int t, int l, int r)
  18. {
  19. tree[t].l = l, tree[t].r = r;
  20. if(l == r) // 叶子节点
  21. {
  22. tree[t].m = a[l];
  23. return; //递归出口
  24. }
  25. int m = (l+r) / 2;
  26. creat(t*2, l, m), creat(t*2+1, m+1, r); // 左孩子
  27. tree[t].m = Max(tree[t*2].m, tree[t*2+1].m); // 右孩子
  28. }
  29. void update(int t, int n, int v) // 把n 点的值更新为v
  30. {
  31. if(tree[t].l == tree[t].r && tree[t].l == n)
  32. {
  33. tree[t].m = v;
  34. return;
  35. }
  36. if(n <= tree[t*2].r) update(t*2, n, v);
  37. else update(t*2+1, n, v);
  38. tree[t].m = Max(tree[t*2].m, tree[t*2+1].m);
  39. }
  40. int query(int t, int l, int r) // 查询t 节点在【l,r】区间范围的最大值
  41. {
  42. if(l == tree[t].l && r == tree[t].r) return tree[t].m;
  43. int s;
  44. if(r <= tree[t*2].r) s = query(t*2, l, r);
  45. else if(l >= tree[t*2+1].l) s= query(t*2+1, l, r);
  46. else s = Max(query(t*2, l, tree[t*2].r), query(t*2+1, tree[t*2+1].l, r));
  47. return s;
  48. }
  49. int main()
  50. {
  51. int n, m, i, x1, x2;
  52. char s[2];
  53. while(scanf("%d%d", &n, &m) != EOF)
  54. {
  55. for(i = 1; i <= n; i++) scanf("%d", &a[i]);
  56. creat(1, 1, n); // 根节点标号为1,区间为【1,n】
  57. while(m--)
  58. {
  59. scanf("%s%d%d", s, &x1, &x2);
  60. if(s[0] == 'Q') printf("%d\n", query(1, x1, x2)); // 查询
  61. else update(1, x1, x2); // 更新
  62. }
  63. }
  64. return 0;
  65. }

HDU 1754 I Hate it (线段树最大值模板)的更多相关文章

  1. hdu 1754 I Hate It 线段树 点改动

    // hdu 1754 I Hate It 线段树 点改动 // // 不多说,裸的点改动 // // 继续练 #include <algorithm> #include <bits ...

  2. hdu 1754 I Hate It (线段树、单点更新)(PS:ios::sync_with_stdio(false)可以加快cin、cout的读取写出速度)

    I Hate ItTime Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  3. HDU 1754 I Hate It 线段树单点更新求最大值

    题目链接 线段树入门题,线段树单点更新求最大值问题. #include <iostream> #include <cstdio> #include <cmath> ...

  4. HDU 1754 I Hate It(线段树之单点更新,区间最值)

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  5. HDU 1754 I Hate It 线段树RMQ

    I Hate It Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=175 ...

  6. HDU 1754 I Hate It (线段树)

    题目链接 Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少. 这让很多学生很反感. 不管你喜不喜欢,现在需要你做的是,就是按照老 ...

  7. hdu 1754 I Hate It (线段树求区间最值)

    HDU1754 I Hate It Time Limit:3000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u D ...

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

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

  9. HDU 1754 I Hate It (线段树)

    题意:略. 析:裸的线段树. 代码如下: #pragma comment(linker, "/STACK:1024000000,1024000000") #include < ...

随机推荐

  1. BZOJ 3681 线段树合并+网络流

    思路: 暴力建图有n*m条边 考虑怎么优化 (那就只能加个线段树了呗) 然后我就不会写了..... 抄了一波题解 //By SiriusRen #include <bits/stdc++.h&g ...

  2. A - Team

    Problem description One day three best friends Petya, Vasya and Tonya decided to form a team and tak ...

  3. fontSpider字蛛,好用的字体压缩工具教程

    一直觉得很多字体特别好看,但是那些好看的字体只能做在图片上不能用CSS样式去实现,作为一个会设计的前端,真心觉得很烦恼,有时候那些文字需要更换,修改起来非常麻烦,要到处去找源文件,找不到源文件还要尽力 ...

  4. 6月10遇到的bug

    3.遇到的BUG        1.@Service(version = "1.0.0", interfaceClass = TransactionItemService.clas ...

  5. Oracle 循环调用存储过程

    create or replace procedure p_test_loop as --定义一个游标,并将查询结果集赋值给它 CURSOR c1 IS select * from tbltest w ...

  6. 酷派 5267 刷入第三方 recovery教程 刷机 ROOT

    准备工作: 一台电脑: 酷派5267手机: 一张内存卡: 下载好刷机资料:  http://pan.baidu.com/s/1i4LoVh7 备用下载: http://pan.baidu.com/s/ ...

  7. VM虚拟机中Ubuntu中执行apt-get update失败的解决方法(可能有效)

    首先确保虚拟机是连接网络的,可以用ping命令检测一下看是否连通网络.采用nat网络的时候确保服务是开的. 如果之前执行过apt-get update命令但是失败了,执行一下      rm -rf ...

  8. java ---书写自己的名字

    public class hello { public static void main(String[] args) { // TODO 自动生成的方法存根 System.out.println(& ...

  9. js 二级联动

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  10. 微信小程序例子-保存图片到手机相册

    微信小程序例子-保存图片到手机相册 1.关键代码 1)WXML文件 2)JS文件 saveImgToPhotosAlbumTap: function(){ // 图片必须是 https 的 var I ...