线段树,最大值查询位子(个人模版)
时间:2022-05-07
本文章向大家介绍线段树,最大值查询位子(个人模版),主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
线段树,最大值查询位子:
1 #include<cstdio>
2 #include<climits>
3 #include<algorithm>
4
5 using namespace std;
6
7 #define lson l, m, rt<<1
8 #define rson m+1, r, (rt<<1)|1
9
10 int tree[111111<<2];
11 int posn[111111<<2];
12 void pushup(int rt)
13 {
14 if (tree[rt<<1] > tree[rt<<1|1])
15 {
16 tree[rt] = tree[rt<<1];
17 posn[rt] = posn[rt<<1];
18 }
19 else
20 {
21 tree[rt] = tree[rt<<1|1];
22 posn[rt] = posn[rt<<1|1];
23 }
24 }
25 void build(int l, int r, int rt)
26 {
27 if (l == r)
28 {
29 scanf("%d", &tree[rt]);
30 posn[rt] = l;
31 }
32 else
33 {
34 int m = (l + r) >> 1;
35 build(lson);
36 build(rson);
37 pushup(rt);
38 }
39 }
40 void update(int p, int val, int l, int r, int rt)
41 {
42 if (l == r)
43 {
44 tree[rt] = val;
45 }
46 else
47 {
48 int m = (l + r) >> 1;
49 if (p <= m)
50 {
51 update(p, val, lson);
52 }
53 else
54 {
55 update(p, val, rson);
56 }
57 pushup(rt);
58 }
59 }
60 int query(int L, int R, int l, int r, int rt, int *pos)
61 {
62 if (L <= l && r <= R)
63 {
64 *pos = posn[rt];
65 return tree[rt];
66 }
67 else
68 {
69 int m = (l + r) >> 1;
70 int ret1 = INT_MIN;
71 int ret2 = INT_MIN;
72 int pa, pb;
73 int *pos1 = &pa;
74 int *pos2 = &pb;
75 if (L <= m)
76 {
77 ret1 = query(L, R, lson, pos1);
78 }
79 if (R > m)
80 {
81 ret2 = query(L, R, rson, pos2);
82 }
83 if (ret1 > ret2)
84 {
85 *pos = pa;
86 }
87 else
88 {
89 *pos = pb;
90 ret1 = ret2;
91 }
92 return ret1;
93 }
94 }
95 int main(void)
96 {
97 int n, m;
98
99 while (scanf("%d", &n) != EOF)
100 {
101 build(1, n, 1);
102
103 scanf("%d", &m);
104 char op[2];
105 int a, b;
106 while (m--)
107 {
108 scanf("%s", op);
109 if (op[0] == 'Q')
110 {
111 int pos;
112 printf("%d %dn", pos, query(1, n, 1, n, 1, &pos));
113 }
114 else
115 {
116 scanf("%d%d", &a, &b);
117 update(a, b, 1, n, 1);
118 }
119 }
120 printf("n");
121 }
122
123 return 0;
124 }
- Git面试常见问题
- 剑指offer代码解析——面试题17合并两个排序的链表
- MySQL优化方案(一)优化SQL脚本与索引
- 从0学习MySQL系列(二)安装篇
- 从0学习MySQL系列(三)概念篇
- SQL Server基础SQL脚本之主外键约束
- SQL Server基础SQL脚本之Group By
- SQL Server基础SQL脚本之内外连接、交叉连接;函数、子查询
- MySQL 面试选择题15道(单选)
- SQL Server基础SQL脚本之分区表、分区方案
- SQL Server基础SQL脚本之创建架构、排序
- 枚举算法(Enumeration algorithm)实例一
- 剑指offer代码解析——面试题16反转单链表
- QMainWindow 和 QWidget 设置layout
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法