e,应该是线段树里的水题。线段树单点更新。查询区间最值。

代码套用模板 PS :模板有些地方不太懂。

#include<stdio.h>
#include<iostream>
#include<string.h>
#define maxn 200010
using namespace std;

int val[maxn];

struct Node
{
    int max;  // 需要求最值这里就改成最值
    int left, right;
}tree[maxn*4]; // 据说。线段树节点需要是数组的3~4倍大

int max(int a, int b)
{
    return a > b ? a : b;
}

int build(int root, int left, int right) // 以root为根节点 left 和 right 为数组长度的树
{
    tree[root].left = left;
    tree[root].right = right;
    if (left == right)
    return tree[root].max = val[left];  // 给叶子节点赋值

int mid = (left + right) / 2;
    int a = build(2*root, left, mid);  // 建立左子树和右子树
    int b = build(2*root+1, mid+1, right);
    return tree[root].max = max(a, b);
}

int update(int root, int pos, int val) //单点更新 把pos 位置的元素更新为val
{
    if (tree[root].left == pos && tree[root].right == pos)    // 如果找到了该位置对应的节点
     return tree[root].max = val;
    if (tree[root].left > pos || tree[root].right < pos)    //如果不是。以上是两种递归突破口。e .但是我不太明白这两种情况返回值为什么是这样的。
     return tree[root].max;
    int a, b;
    a = update(2*root, pos, val);  // 更新左子树和右子树
    b = update(2*root+1, pos, val);
    return tree[root].max = max(a, b);
}

int calculate(int root, int left, int right) // 求取区间left 到 right中的最大值
{
    if (tree[root].left > right || tree[root].right < left)  // 如果当前区间和所求区间没有交集
      return 0;
    if (left <= tree[root].left && tree[root].right <= right)  // 如果当前区间完全包含在所求区间里。不明白为什么就要返回当前区间的最大值。
      return tree[root].max;
    int a, b;
    a = calculate(2*root, left, right);  // 上述两种情况都木有的话。需要分解所求区间,求子区间的最值。
    b = calculate(2*root+1, left, right);
    return max(a, b);
}

int main()
{
    int n, m;
    while(cin >> n >> m)
    {
        for (int i=1; i<=n; ++i)
         scanf("%d", &val[i]);
        build(1, 1, n);
        while(m--)
        {
            char temp;
            int a, b;
            cin >> temp >> a >> b;
            if (temp == 'Q')
              cout << calculate(1, a, b) << endl;
            else update(1, a, b);
        }
    }
    return 0;
}

POJ 1754 线段树的更多相关文章

  1. poj 2886 线段树+反素数

    Who Gets the Most Candies? Time Limit: 5000MS   Memory Limit: 131072K Total Submissions: 12744   Acc ...

  2. hdu 1754 线段树(Max+单点修改)

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

  3. HDU(1754),线段树,单点替换,区间最值

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1754 线段树模板题,update功能是单点替换,query是访问区间最大值. #include < ...

  4. poj 3468(线段树)

    http://poj.org/problem?id=3468 题意:给n个数字,从A1 …………An m次命令,Q是查询,查询a到b的区间和,c是更新,从a到b每个值都增加x.思路:这是一个很明显的线 ...

  5. POJ——3264线段树

    题目: 输入两个数(m,n),m表示牛的头数,n表示查询的个数.查询时输入两个数(x,y),表示查询范围的起始值和终止值,查询结果是,这个区间内牛重量的最大值减去牛重量的最小值,数量级为1000,00 ...

  6. POJ 2828 线段树(想法)

    Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 15422   Accepted: 7684 Desc ...

  7. poj 2828 线段树

    http://poj.org/problem?id=2828 学到的思维: 1.变化的或者后来的优先影响前面的,那么从最后一个往前看,最后一个就成了 确定的, 而且后来的也能够确定----假设从前往后 ...

  8. POJ - 1177 线段树

    POJ - 1177 扫描线 这道题也算是一道扫描线的经典题目了. 只不过这道题是算周长,非常有意思的一道题.我们已经知道了,一般求面积并,是如何求的,现在我们要把扫描线进行改造一下,使得能算周长. ...

  9. poj 2886 (线段树+反素数打表) Who Gets the Most Candies?

    http://poj.org/problem?id=2886 一群孩子从编号1到n按顺时针的方向围成一个圆,每个孩子手中卡片上有一个数字,首先是编号为k的孩子出去,如果他手上的数字m是正数,那么从他左 ...

随机推荐

  1. 20145335郝昊《网络攻防》Exp4 Adobe阅读器漏洞攻击

    20145335郝昊<网络攻防>Exp4 Adobe阅读器漏洞攻击 实验内容 初步掌握平台matesploit的使用 有了初步完成渗透操作的思路 本次攻击对象为:windows xp sp ...

  2. Python3基础 str """ 多行字符串

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  3. 在CentOS Linux系统上,添加新的端口,启用ssh服务

    SSH作为Linux远程连接重要的方式,如何配置安装linux系统的SSH服务,如何开启SSH? SSH是什么? SSH 为 Secure Shell 由 IETF 的网络工作小组(Network W ...

  4. poj3352 Road Construction & poj3177 Redundant Paths (边双连通分量)题解

    题意:有n个点,m条路,问你最少加几条边,让整个图变成边双连通分量. 思路:缩点后变成一颗树,最少加边 = (度为1的点 + 1)/ 2.3177有重边,如果出现重边,用并查集合并两个端点所在的缩点后 ...

  5. hdu4528 小明系列故事——捉迷藏(记录状态的BFS)题解

    思路: 一道BFS题,和以前的BFS有点不同,这里的vis数组需要记录每次走时的状态,所以开了3维,只对该状态下的vis修改. 注意坑点:S的位置是可以走的 代码: #include<queue ...

  6. 【问题解决】An internal error occurred during: "Computing additional info". Could not initialize class javax.crypto.JceSecurityManager

    在使用eclipse时对象后使用点操作符时总是会弹出错误,很是烦人 An internal error occurred during: "Computing additional info ...

  7. [js] - 关于js的排序sort

    js的排序sort并不能一次排序好 function solution(nums){ return nums.sort(sortNumber); } function sortNumber(a, b) ...

  8. HDU 2874 Connections between cities(LCA离线算法实现)

    http://acm.hdu.edu.cn/showproblem.php?pid=2874 题意: 求两个城市之间的距离. 思路: LCA题,注意原图可能不连通. 如果不了解离线算法的话,可以看我之 ...

  9. ubuntu-server14.04 网络配置

    一.启动网卡 ubuntu server 安装后,ifconfig 发现只有一个lo 和一个p1p1 网卡, 先查看服务器网卡:ifconfig -a ,发现有lo ,p1p1,p2p1,p3p1,p ...

  10. TimeZone 时区 (JS .NET JSON MYSQL) + work week 闰年

    来源参考 : http://www.cnblogs.com/qiuyi21/archive/2008/03/04/1089456.html 来源参考 : http://walkingice.blogs ...