热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

算法学习ST表稀疏表解决RMQ问题

2017-08-2621:44:45writer:pprpRMQ问题就是区间最大最小值查询问题;这个SparseTable算法构造一个表,

2017-08-26 21:44:45

writer:pprp

RMQ问题就是区间最大最小值查询问题;

这个SparseTable算法构造一个表,F[i][j] 表示 区间[i, i + 2 ^ j -1]的最大或者最小值

ST分为两个部分

1、nlogn的预处理

预处理主要用到了动态规划,二分区间每个区间长度为 2 ^ (j -1)找到一个递推关系;

F[i][j] &#61; min(F[i][j - 1],F[i &#43; (1 <<(j - 1))][j - 1]);

2、查询部分更为巧O(1)得到询问结果

对于任意一个区间【n,m】来说&#xff0c;可以将其划分为两个以上区间的和

【m,n】 &#61; 【m, m&#43;2^k-1】 &#43; 【n-2^k-1,n】

其中k &#61; log2(n-m&#43;1)

实现的代码如下&#xff1a;

/*
&#64;theme:ST表&#xff08;sparse table&#xff09;稀疏表
&#64;writer:pprp
&#64;declare:用动态规划的思想来解决RMQ问题&#xff1b;
&#64;date:2017/8/26
*//*方程
F[i,j]:区间[i,i &#43; 2^j - 1]的最小值&#xff0c;此时区间长度为2^j
转移方程&#xff1a;F[i,j] &#61; min(F[i,j - 1],F[i &#43; 2^(j - 1),j - 1])
初始化&#xff1a;F[i,0] &#61; nArr[i];
*/#include using namespace std;int F[1000000][20];//待比较元素的个数最大为1百万void SparseTable(int a[], int len)
{
//初始化for(int i &#61; 0 ; i )F[i][
0] &#61; a[i];//递推//找到j的范围log2(n)int nlog &#61; int(log(double(len))/log(2.0));for(int j &#61; 1 ; j <&#61; nlog; j&#43;&#43;){for(int i &#61; 0 ; i ){//区间右端点不能超过数组最后一位下标if((i &#43; (1 <1) < len ){F[i][j] &#61; min(F[i][j - 1],F[i &#43; (1 <<(j - 1))][j - 1]);}}}
}
int RMQ(int a[], int len, int Start, int End)
{
//中间变量的选取log2(len)int nlog &#61; (int)(log(double(End-Start&#43;1))/log(2.0));return min(F[Start][nlog], F[End - (1 <1][nlog]);
}
int main()
{
int a[] &#61; {2,34,2,3,23,2,23,1,23,123,23,232,3,25,565,76};for(int i &#61; 0 ; i <16 ; i&#43;&#43;){cout <" ";}cout << endl;SparseTable(a,16);int l, r;while(cin >> l >> r){cout <16,l,r) << endl;}return 0;
}

 ST模板

#include using namespace std;int F[1000000][20];
void ST(int a[],int len)
{
for(int i &#61; 0 ; i )F[i][0] &#61; a[i];int nlog &#61; int(log(double(len))/log(2.0));for(int j &#61; 1; j <&#61; nlog; j&#43;&#43;){for(int i &#61; 0 ; i ){if(i&#43;(1<1 < len)F[i][j] &#61; max(F[i][j-1],F[i&#43;(1<<(j-1))][j-1]);}}
}
int RMQ(int a[],int len, int l, int r)
{
int nlog &#61; floor(log(double(r-l&#43;1))/log(2.0));return max((F[l][nlog]),F[r-(1<1][nlog]);
}
int main()
{
int a[10000];int n;cin >> n;for(int i &#61; 0 ; i )cin >> a[i];ST(a,n);int l,r;int cas;cin >> cas;while(cas--){cin >> l >> r;cout < endl;}return 0;
}

 

转:https://www.cnblogs.com/pprp/p/7436498.html



推荐阅读
  • C++入门必备:首个博客知识点汇总
    本文总结了C++初学者需要掌握的关键知识点,特别强调了成员类型的区分。其中,protected成员与private成员在本类中的作用相同,但protected成员允许派生类的成员函数访问,而private成员则不允许。此外,文章还介绍了其他重要的C++基础概念,如类的构造函数、析构函数以及继承机制,为初学者提供了一个全面的学习指南。 ... [详细]
  • 本文介绍了UUID(通用唯一标识符)的概念及其在JavaScript中生成Java兼容UUID的代码实现与优化技巧。UUID是一个128位的唯一标识符,广泛应用于分布式系统中以确保唯一性。文章详细探讨了如何利用JavaScript生成符合Java标准的UUID,并提供了多种优化方法,以提高生成效率和兼容性。 ... [详细]
  • 在解决区间相关问题时,我发现自己经常缺乏有效的思维方式,即使是简单的题目也常常需要很长时间才能找到解题思路,而一旦得到提示便能迅速理解。题目要求对一个包含n个元素的数组进行操作,并给出一个参数k,具体任务是…… ... [详细]
  • Golomb 编码是一种高效的变长编码技术,专门用于整数的压缩。该方法通过预定义的参数 \( M \) 将输入整数分解为商 \( q \) 和余数 \( r \) 两部分。具体而言,输入整数除以 \( M \) 得到商 \( q \) 和余数 \( r \),其中商 \( q \) 采用一元编码表示,而余数 \( r \) 则使用二进制编码。这种编码方式在数据压缩和信息传输中具有显著的优势,特别是在处理具有特定概率分布的数据时表现出色。 ... [详细]
  • 在SWUSTOJ #1063中,题目要求对带权重的有向图进行算法计算与分析。假设图G使用邻接矩阵存储,任务是计算图中的最大权值和最小权值,并确定对应的有向边。输入数据的第一行包含一个整数n,表示图中节点的数量。随后的输入将提供图的边及其权重信息。通过该算法,可以有效地找出图中的关键路径和最短路径,为图论问题的解决提供重要参考。 ... [详细]
  • HDU1176:免费馅饼问题的动态规划解法分析
    题目“免费馅饼”通过动态规划方法进行了解析。该问题的时间限制为 Java 2000ms 和其他语言 1000ms,内存限制为 Java 65536K 和其他语言 32768K。本文详细探讨了如何利用动态规划算法高效求解此问题,并对算法的时间复杂度和空间复杂度进行了深入分析。此外,还提供了具体的实现步骤和代码示例,帮助读者更好地理解和应用这一方法。 ... [详细]
  • 本文探讨了在形状类族中应用纯虚函数的设计模式及其解析方法。通过定义一个基类 `Shape`,其中包含一个纯虚函数 `area()`,实现了多态性和代码的灵活性。该设计使得派生类能够根据具体的形状计算面积,从而提高了代码的可扩展性和复用性。示例代码展示了如何利用纯虚函数实现这一机制。 ... [详细]
  • 本文详细介绍了在 Vue.js 前端框架中集成 vue-i18n 插件以实现多语言支持的方法。通过具体的配置步骤和示例代码,帮助开发者快速掌握如何在项目中实现国际化功能,提升用户体验。同时,文章还探讨了常见的多语言切换问题及解决方案,为开发人员提供了实用的参考。 ... [详细]
  • 在腾讯云服务器上部署Nginx的详细指南中,首先需要确保安装必要的依赖包。如果这些依赖包已安装,可直接跳过此步骤。具体命令包括 `yum -y install gcc gcc-c++ wget net-tools pcre-devel zlib-devel`。接下来,本文将详细介绍如何下载、编译和配置Nginx,以确保其在腾讯云服务器上顺利运行。此外,还将提供一些优化建议,帮助用户提升Nginx的性能和安全性。 ... [详细]
  • Python 实战:异步爬虫(协程技术)与分布式爬虫(多进程应用)深入解析
    本文将深入探讨 Python 异步爬虫和分布式爬虫的技术细节,重点介绍协程技术和多进程应用在爬虫开发中的实际应用。通过对比多进程和协程的工作原理,帮助读者理解两者在性能和资源利用上的差异,从而在实际项目中做出更合适的选择。文章还将结合具体案例,展示如何高效地实现异步和分布式爬虫,以提升数据抓取的效率和稳定性。 ... [详细]
  • 在牛客2021多校竞赛的一道题目中,涉及了5000×5000×5000的复杂度计算。实验结果显示,使用bitset进行数据处理仅需140毫秒,而使用bool数组则显著较慢。本文通过详细的性能分析,探讨了bitset与bool在数据处理速度上的差异,并提出了针对不同应用场景的优化建议。具体来说,bitset在位级操作上具有更高的效率,适用于大规模数据处理任务,而bool数组则在某些特定场景下更为灵活。通过对这两种数据结构的深入对比,本文旨在为开发者提供选择合适数据结构的参考依据。 ... [详细]
  • 利用Flask框架进行高效Web应用开发
    本文探讨了如何利用Flask框架高效开发Web应用,以满足特定业务需求。具体案例中,一家餐厅希望每天推出不同的特色菜,并通过网站向顾客展示当天的特色菜。此外,还增加了一个介绍页面,在bios路径下详细展示了餐厅主人、厨师和服务员的背景和简介。通过Flask框架的灵活配置和简洁代码,实现了这一功能,提升了用户体验和餐厅的管理水平。 ... [详细]
  • 如何高效启动大数据应用之旅?
    在前一篇文章中,我探讨了大数据的定义及其与数据挖掘的区别。本文将重点介绍如何高效启动大数据应用项目,涵盖关键步骤和最佳实践,帮助读者快速踏上大数据之旅。 ... [详细]
  • 指针内容的扩展与深化解析 ... [详细]
  • 本文详细解析了九度编程平台上的斐波那契数列高效算法挑战(题目编号:1387)。该挑战要求在1秒的时间限制和32兆的内存限制下,设计出高效的斐波那契数列计算方法。通过多种算法的对比和性能分析,本文提供了优化方案,帮助参赛者在限定资源条件下实现高效计算。 ... [详细]
author-avatar
炜一爱妮
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有