博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
线段树,最大值查询位子(个人模版)
阅读量:6877 次
发布时间:2019-06-26

本文共 2642 字,大约阅读时间需要 8 分钟。

线段树,最大值查询位子:

1 #include
2 #include
3 #include
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 %d\n", pos, query(1, n, 1, n, 1, &pos));113 }114 else115 {116 scanf("%d%d", &a, &b);117 update(a, b, 1, n, 1);118 }119 }120 printf("\n");121 }122 123 return 0;124 }

 

转载于:https://www.cnblogs.com/ECJTUACM-873284962/p/6562247.html

你可能感兴趣的文章
一切属他,则名为苦;一切由己,自在安乐。
查看>>
velocity 之坑:不同枚举类(enum)有相同的静态(static)方法,无法访问第二个枚举类...
查看>>
图的遍历方法(深度优先和广度优先算法)
查看>>
鸟巢-一种全新的Native APP开发模式,这篇文章为您解读
查看>>
shell批量查询IP
查看>>
快速生成移动设备应用图标的在线工具 - makeappicon
查看>>
学习linux决心书
查看>>
SVN服务的搭建
查看>>
ISO 9126质量模型:软件质量模型的6大特性和27个子特性
查看>>
一个 rm -rf的教训
查看>>
几何画板添加背景图片方法
查看>>
用main函数传参做简单的计算器的代码
查看>>
Bash终端命令行,使用privoxy将socks代理转成http代理
查看>>
Linux基础命令
查看>>
if case 语句 find locate 文件查找 和 压缩解压缩工具 简介
查看>>
Linux常用命令——tr
查看>>
检测 ip 是否断开,并使用邮箱报警
查看>>
整理第一周学习C的知识点
查看>>
Spring Data JPA 实例查询
查看>>
ping多线程
查看>>