首页 > 代码库 > HDU 1754 I Hate it (线段树最大值模板)
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\n", query(1, x1, x2)); // 查询 else update(1, x1, x2); // 更新 } } return 0; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。