首页 > 其他 > 详细

HDU 1754 I Hate It 线段树

时间:2017-05-24 20:48:58      阅读:319      评论:0      收藏:0      [点我收藏+]

  题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1754

  题目描述:中文, 自己去看

  解题思路:线段树还是单点更新, 不过由之前的加和变成了最大值稍微的改动一下

  代码:

技术分享
#include <iostream>
#include <cstdio>
#include <algorithm>
#define lson l, m, rt << 1
#define rson m+1, r, rt << 1 | 1
#define INF 0x3fffffff
using namespace std;

const int MAXN = 200020;
int MAX[MAXN<<2];

void PushUp(int rt) {
    MAX[rt] = max( MAX[rt<<1], MAX[rt<<1|1] );
}
void build(int l, int r, int rt) {
    if( l == r ) {
        scanf("%d", &MAX[rt]);
        return;
    }
    int m = (l+r)>>1;
    build(lson);
    build(rson);
    PushUp(rt);
}

void update(int p, int value, int l, int r, int rt) {
    if(l == r) {
        MAX[rt] = value;
        return;
    }
    int m = (l+r)>>1;
    if(p <= m) update(p, value, lson);
    else update(p, value, rson);
    PushUp(rt);
}

int query(int L, int R, int l, int r, int rt) {
    
    if(L <= l && r <= R) {
        return MAX[rt];
    }
    int m = (l+r)>>1;
    int ret = 0;
    if( L <= m ) ret = max( ret, query( L, R, lson) );
    if( R > m ) ret = max( ret, query(L, R, rson) );
    return ret;
}

int main() {
    
    int n, m;
    while( scanf("%d%d", &n, &m) == 2 ) {
        build( 1, n, 1 );
        while( m-- ) {
            char op[2];
            int a, b;
            scanf( "%s%d%d", op, &a, &b );
            if( op[0] == U ) {
                update(a, b, 1, n, 1);
            }
            else {
                printf( "%d\n", query(a, b, 1, n, 1) );
            }
        }
    }
    

    return 0;
}
View Code

  思考:还是线段树, 这是最基本的改动了, 要理解一个板子, 就要连最底层都了解, 我是这么认为的。

HDU 1754 I Hate It 线段树

原文:http://www.cnblogs.com/FriskyPuppy/p/6900748.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!