博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
稀疏表(ST / Sparse Table)
阅读量:4617 次
发布时间:2019-06-09

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

RMQ问题:

给定一个序列,每次询问一个区间最小值 / 最大值。

没有修改。

 

 

//拿区间最大值来举例。memset(ans, -INF, sizeof(ans));for (int i = 1; i <= n; i++)        ans[i][0] = a[i];for (int j = 1; (1<
<= n; j++) //枚举长度为2^j的区间 for (int i = 1; i+(1<
<= n; i++)  //枚举区间起点 ans[i][j] = max(ans[i][j-1], ans[i+(1<<(j-1))][j-1]);            //显然,长度为2^j的区间由2^(j-1)的区间更新。for (int i = 1; i <= q; i++){ int l, r, k = 0; scanf("%d%d", &l, &r); while((1<<(k+1)) <= r-l+1) k++;        //若2^k+1还是不超过所求区间的长度,那么说明k可以继续加1 printf("%d\n", max(ans[l][k], ans[r-(1<

  

转载于:https://www.cnblogs.com/ruthank/p/9460401.html

你可能感兴趣的文章
把 MongoDB 当成是纯内存数据库来使用(Redis 风格)
查看>>
PyTorch 1.0 中文官方教程:使用ONNX将模型从PyTorch传输到Caffe2和移动端
查看>>
LeetCode 4Sum
查看>>
(Kinetis K60)外部引脚中断
查看>>
[Loading Component]Loading组件的v-model设计是否不合理?
查看>>
博客园电子期刊2012年8月刊发布啦
查看>>
MVC – 7.Razor 语法
查看>>
windows环境中mysql忘记root密码的解决办法
查看>>
利用nginx向现有网站添加登录验证功能(不添加修改现有网站代码)
查看>>
Python pip国内源
查看>>
cocopod安装
查看>>
Atitit.数据索引 的种类以及原理实现机制 索引常用的存储结构
查看>>
哈夫曼树
查看>>
JS计算日期差
查看>>
2017最新高清仿驴妈妈旅行网大数据分析项目实战演练培训视频 228课
查看>>
数据结构综合性实验:多种功能的平衡二叉排序树
查看>>
[九度OJ]1011.最大连续子序列
查看>>
羊车门(作业)
查看>>
对C#中的Close()和Dispose()的浅显理解
查看>>
【手记】小心在where中使用NEWID()的大坑
查看>>