zoukankan      html  css  js  c++  java
  • HDU 1754 I Hate it (线段树最大值模板)

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

    AC代码:

    #include<iostream>
    #include<cstdio>
    #include<cmath>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    inline int Max(int a, int b)
    {
    	return a > b ? a : b;
    }
    const int MAXN = 200001; // 区间范围
    struct
    {
    	int l, r, m; // l 左端点,r 右端点。m 为该区间的最大分数
    } tree[MAXN*4];
    int a[MAXN];
    void creat(int t, int l, int r)
    {
    	tree[t].l = l, tree[t].r = r;
    	if(l == r) // 叶子节点
    	{
    		tree[t].m = a[l];
    		return; //递归出口
    	}
    	int m = (l+r) / 2;
    	creat(t*2, l, m), creat(t*2+1, m+1, r); // 左孩子
    	tree[t].m = Max(tree[t*2].m, tree[t*2+1].m); // 右孩子
    }
    void update(int t, int n, int v) // 把n 点的值更新为v
    {
    	if(tree[t].l == tree[t].r && tree[t].l == n)
    	{
    		tree[t].m = v;
    		return;
    	}
    	if(n <= tree[t*2].r) update(t*2, n, v);
    	else update(t*2+1, n, v);
    	tree[t].m = Max(tree[t*2].m, tree[t*2+1].m);
    }
    int query(int t, int l, int r) // 查询t 节点在【l,r】区间范围的最大值
    {
    	if(l == tree[t].l && r == tree[t].r) return tree[t].m;
    	int s;
    	if(r <= tree[t*2].r) s = query(t*2, l, r);
    	else if(l >= tree[t*2+1].l) s= query(t*2+1, l, r);
    	else s = Max(query(t*2, l, tree[t*2].r), query(t*2+1, tree[t*2+1].l, r));
    	return s;
    }
    int main()
    {
    	int n, m, i, x1, x2;
    	char s[2];
    	while(scanf("%d%d", &n, &m) != EOF)
    	{
    		for(i = 1; i <= n; i++) scanf("%d", &a[i]);
    		creat(1, 1, n); // 根节点标号为1,区间为【1,n】
    		while(m--)
    		{
    			scanf("%s%d%d", s, &x1, &x2);
    			if(s[0] == 'Q') printf("%d
    ", query(1, x1, x2)); // 查询
    			else update(1, x1, x2); // 更新
    		}
    	}
    	return 0;
    }
    


  • 相关阅读:
    js基础四
    序列化和反序列化
    数组
    枚举
    Class对象和反射
    字符串String
    对象的克隆
    异常处理机制
    多继承和代码块
    接口和抽象类
  • 原文地址:https://www.cnblogs.com/lxjshuju/p/6995072.html
Copyright © 2011-2022 走看看