hdu 1754 I Hate It

简介: 点击打开链接hdu 1754 思路: 线段树+单点更新 分析: 1 线段树的水题 代码: /************************************************ * By: chenguolin ...

点击打开链接hdu 1754

思路: 线段树+单点更新

分析:

1 线段树的水题


代码:

/************************************************
 * By: chenguolin                               * 
 * Date: 2013-09-01                             *
 * Address: http://blog.csdn.net/chenguolinblog *
 ************************************************/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

#define Lson(x) (x<<1)
#define Rson(x) (Lson(x)|1)
#define Mid(x,y) ((x+y)>>1)
#define Sum(x,y) (x+y)

const int MAXN = 200010;

int n , m;
int num[MAXN];
struct Node{
    int left;
    int right;
    int maxScore; 
};
Node node[4*MAXN];

void push_up(int pos){
    node[pos].maxScore = max(node[Lson(pos)].maxScore , node[Rson(pos)].maxScore);
}

void init(int left , int right , int pos){
    node[pos].left = left;
    node[pos].right = right;
    if(node[pos].left == node[pos].right){
        node[pos].maxScore = num[left];
        return;
    }
    int mid = Mid(left , right);
    init(left , mid , Lson(pos));
    init(mid+1 , right , Rson(pos));
    push_up(pos); 
}

void update(int index , int val , int pos){
    if(node[pos].left == node[pos].right){
        node[pos].maxScore = val;
        return;
    }
    int mid = Mid(node[pos].left , node[pos].right);
    if(index <= mid)
        update(index , val , Lson(pos));
    else
        update(index , val , Rson(pos));
    push_up(pos); 
}

int query(int left , int right , int pos){
    if(node[pos].left == left && node[pos].right == right) 
        return node[pos].maxScore;
    int mid = Mid(node[pos].left , node[pos].right);
    if(right <= mid)
        return query(left , right , Lson(pos));
    else if(left > mid)
        return query(left , right , Rson(pos));
    else
        return max(query(left , mid , Lson(pos)),query(mid+1 , right , Rson(pos)));
}

void input(){
    char c;
    int x , y;
    for(int i = 1 ; i <= n ; i++) 
        scanf("%d%*c" , &num[i]);
    init(1 , n , 1);
    while(m--){
        scanf("%c%d%d%*c" , &c , &x , &y);
        if(c == 'Q'){
            printf("%d\n" , query(x , y , 1));
        }
        else
            update(x , y , 1);
    }
}

int main(){
    while(scanf("%d%d" , &n , &m) != EOF)
        input();
    return 0;
}



目录
相关文章
|
8月前
|
机器学习/深度学习 存储 人工智能
HDU - 5912——Fraction
HDU - 5912——Fraction
HDU2203亲和串
博客水平见水平......目前阶段就是这么菜,我会好好努力的!毕业直接拿到阿里offer!
1232 0
|
机器学习/深度学习
hdu 2604 Queuing
点击打开hdu 2604 思路: 递推+矩阵快速幂 分析; 1 根据题目的意思,我们可以求出F[0] = 0 , F[1] = 2 , F[2] = 4 , F[3] = 6 , F[4] = 9 , F[5] = 15 2 那么根据上面...
811 0
|
机器学习/深度学习 人工智能
HDU 2674
  题意:求N!mod2009,N=41时,N!因式分解一定含7*7*41,即N!%2009=0.所以只要计算0
721 0
|
机器学习/深度学习
hdu 1879 继续畅通工程
点击打开链接1879 /* 1思路:最小生成树+kruskal 2注意把已经建好的合并 */ #include #include #include #include using namespace std; #define MAXN 110...
769 0

热门文章

最新文章