倍增(小试牛刀)

news2025/7/20 21:11:43

二分每次折半,倍增每次2的倍数

原理先存储每个小区间的最值也就是初始化,之后直接查询

1. 把数列按倍增分成小区间

对数列的每个元素,把从它开始的数列分成长度为1、2、4、8、…的小区间。下图给出了一个分区的例子,它按小区间的长度分成了很多组。

  • 第 1 组是长度为 1 的小区间,有 n 个小区间,每个小区间有 1 个元素;
  • 第 2 组是长度为 2 的小区间,有 n 个小区间,每个小区间有 2 个元素;
  • 第 3 组是长度为 4 的小区间,有 n 个小区间,每个小区间有 4 个元素;
  • ...共有 logn (2为底)组。

每组的小区间的最值,可以从前一组递推而来。例如第 3 组 {4, 7, 9, 6} 的最值,可以从第 2 组 {4, 4,7}、{9,6} 的最值递推得到。

所以我们定义 dp[s][k],表示左端点是 s,区间长度为 2^k 的区间最值。它的递推关系是:(1<<(k-1) 等于 2^{k-1})

所以:dp[s][k]=min(dp[s][k−1],dp[s+1<<(k−1)][k−1])

dp[s][k]当前组,是由后面两组推导出来的

图中的每一组都需计算 n 次,共 logn组,总计算量是 O(nlogn)。

2.查询

查询区间[L,R]的最值,L是左端点,R是右端点,区间长度len=R-L+1,区间长度为 2^k 的最值2^k=len

所以k=log(R-L+1)  (2为底,注意Java中的Math.log(n)是以e为底

如果以10为底的话 k=log(R-L+1)/log(2.0)           (换底公式)

最后给出区间 [L, R]最小值的计算公式,等于覆盖它的两个小区间的最小值:

min(dp[L][k],dp[R−(1<<k)+1][k]);             (1<<k也就是2^k)

3.题目练习

https://www.lanqiao.cn/problems/1205/learning/

区间最大值

给定一个长度为 N 的数组 a,其值分别为 a1,a2,...,aN 
现有 Q 个询问,每个询问包含一个区间,请回答该区间的最大值为多少。

输入描述
输入第 1行包含两个正整数 N,Q,分别表示数组 a的长度和询问的个数。

第 2 行包含 N 个非负整数 a1,a2,...,aN ,表示数组 a 元素的值。

后面每行表示一个询问,每个询问包含两个整数 L,R,表示区间的左右端点

1<=N,Q<=5*10^5   -10^9<=ai<=10^9
输出描述
输出共 Q 行,每行包含一个整数,表示相应询问的答案。

输入输出样例
示例 1
输入

5 5
1 2 3 4 5
1 1 
1 2 
1 3
3 4
2 5

输出

1
2
3
4
5


import java.util.Scanner;

public class Main {
	static int N=500000;
	static int n,m;
	static int L,R;
	static int a[]=new int[N];
	//第二个参数是k 设为40即可,也可其他
	static int dp_max[][]=new int[N][40];
	
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		n=sc.nextInt();
		m=sc.nextInt();
		for(int i=1;i<=n;i++) {
			a[i]=sc.nextInt();
		}
		st_init();
		for(int j=1;j<=m;j++){		
	        L=sc.nextInt();
	        R=sc.nextInt();	  
	        System.out.println(st_query(L,R));
	    }
		
	}


	// 把数列按倍增分成小区间
	public static void st_init(){
	    for(int i=1;i<=n;i++)   //初始化区间长度为1时的值
	        dp_max[i][0]=a[i];  
	    	int p=(int)(Math.log10(n)/Math.log10(2.0));     
	    
	    for(int k=1;k<=p;k++) //倍增计算小区间。先算小区间,再算大区间,逐步递推
	        for(int s=1;s+(1<<k)<=n+1;s++)
	            dp_max[s][k]=Math.max(dp_max[s][k-1], dp_max[s+(1<<(k-1))][k-1]);
	}
	//查询
	public static int st_query(int L,int R){
		int k =(int)(Math.log10(R-L+1)/Math.log10(2.0));           
	    return Math.max(dp_max[L][k],dp_max[R-(1<<k)+1][k]);
	}
}

https://www.lanqiao.cn/problems/1375/learning/

同理



import java.util.Scanner;

public class Main {
	static int N=500000;
	static int n,m;
	static int L,R;
	static int a[]=new int[N];
	//第二个参数是k 设为40即可,也可其他
	static int dp_min[][]=new int[N][40];
	
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		n=sc.nextInt();
		m=sc.nextInt();
		for(int i=1;i<=n;i++) {
			a[i]=sc.nextInt();
		}
		st_init();
		for(int i=1;i<=n-m+1;i++){		
	        System.out.println(st_query(i,i+m-1));
	    }
		
	}


	// 把数列按倍增分成小区间
	public static void st_init(){
	    for(int i=1;i<=n;i++)   //初始化区间长度为1时的值
	        dp_min[i][0]=a[i];  
	    	int p=(int)(Math.log10(n)/Math.log10(2.0));     
	    
	    for(int k=1;k<=p;k++) //倍增计算小区间。先算小区间,再算大区间,逐步递推
	        for(int s=1;s+(1<<k)<=n+1;s++)
	            dp_min[s][k]=Math.min(dp_min[s][k-1], dp_min[s+(1<<(k-1))][k-1]);
	}
	//查询
	public static int st_query(int L,int R){
		int k =(int)(Math.log10(R-L+1)/Math.log10(2.0));           
	    return Math.min(dp_min[L][k],dp_min[R-(1<<k)+1][k]);
	}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/37704.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java--JVM

JVM1.JVM的内存结构2.哪些部分会出现内存溢出3.方法区与永久代、元空间之间的关系4.JVM内存参数5.JVM垃圾回收算法&#xff08;1&#xff09;标记清除&#xff08;2&#xff09;标记整理&#xff08;3&#xff09;标记复制6.GC和分代回收算法7.三色标记和并发漏标问题8.垃圾回收…

【分布式技术专题】「Zookeeper中间件」给大家学习一下Zookeeper的”开发伴侣”—Curator-Framework(基础篇)

CuratorFramework基本介绍 CuratorFramework是Netflix公司开源的一套Zookeeper客户端框架&#xff0c;它作为一款优秀的ZooKeeper客户端开源工具&#xff0c;主要提供了对客户端到服务的连接管理和连接重试机制&#xff0c;以及一些扩展功能&#xff0c;它解决了很多ZooKeeper…

Linux服务器配置与管理(基于Centos7.2)任务目标(四)

文章目录一、任务目标二、任务资讯三、任务实施3-1.RPM软件包管理3-2.YUM方式安装软件一、任务目标 实施该工单的任务目标如下&#xff1a; 知识目标 1.了解RPM提供的功能。 2.了解YUM相对于RPM所具有的优点。 能力目标 1.能够通过RPM安装及管理软件包。 2.能够通过YUM安装及管…

uni-app —— 小程序加入购物车实现过程

文章目录 前言一、示意图二、整体实现思路三、实现过程 1.加入购物车2.获取当前用户购物车信息3.解决数据获取不及时的问题总结前言 前文已经讲解了如何实现商品规格的选择&#xff0c;那么接下来就应该将用户选中的商品加入购物车啦&#xff01;那么如何实现呢&#xff1f;请…

[附源码]计算机毕业设计JAVA儒家文化网站

[附源码]计算机毕业设计JAVA儒家文化网站 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis M…

FilterListenerAjax的介绍

目录 一、Filter 1、Filter概述 2、过滤器链 二、Listener 三、Ajax 1、基本介绍 2、快速入门案例 3、axios 4、JSON 一、Filter 1、Filter概述 ▶ 过滤器 Filter 表示过滤器&#xff0c;是 JavaWeb 三大组件(Servlet、Filter、Listener)之一。过滤器可以把对资源的请…

Centos--基于Jdk1.8环境安装+卸载Jenkins

基础准备 本人选择的安装的环境基于jdk1.8 操作系统&#xff1a;Centos7.9 java: 1.8.0_262 检查是否有旧版本 $rpm -ql jenkins 如果有老版本可以卸载后&#xff0c;再执行后面的安装步骤 卸载 jenkins $rpm -e jenkins —删除遗留文件: $find / -iname jenkins | xa…

【Lilishop商城】No2-4.确定软件架构搭建三(本篇包括ES检索)

仅涉及后端&#xff0c;全部目录看顶部专栏&#xff0c;代码、文档、接口路径在&#xff1a; 【Lilishop商城】记录一下B2B2C商城系统学习笔记~_清晨敲代码的博客-CSDN博客 全篇只介绍重点架构逻辑&#xff0c;具体编写看源代码就行&#xff0c;读起来也不复杂~ 谨慎&#xff…

windows文本绘制 TextOut、DrawText、CreateFont、SetTextColor、SetBkColor、SetBkMode

文本绘制 TextOut-将文字绘制在指定坐标位置 DrawText-在矩形区域绘制字符串 int DrawText(HDC hdc, //DC句柄LPCSTR lpString, //字符串int nCount, //字符串长度LPRECT lpRect, //绘制文字的矩形框UINT uFormat //绘制的方式,重点&#xff0c;花样繁多的关键点 );绘制文字样…

持续集成和上传源码

1.测试左移&#xff0c;测试右移 2.持续集成 是指通过自动化的方式&#xff0c;频繁多次将代码集成到主干。 快速发现错误 每完成一点更新&#xff0c;就集成到主干&#xff0c;可以快速发现错误&#xff0c;定位错误也比较容易。 防止分支大幅偏离主干 如果不是经常集成&…

nginx源码分析--双端列表

1.基本数据结构 struct ngx_queue_s {ngx_queue_t *prev;ngx_queue_t *next; };结构成员: ngx_queue_t *prev;前驱指针 ngx_queue_t *next;后继指针 2.操作函数--头结点 2.1基本函数 define ngx_queue_init(q) \(…

七牛云 vue 图片上传简单解说,js 上传文件图片

七牛云 vue 图片上传简单解说&#xff0c;js 上传文件图片 一、七牛云简介 首次使用七牛云存储进行项目的图片存储&#xff0c;整了一上午才整明白&#xff0c;这些官方的教程把明白人也给说糊涂了&#xff0c;文档很不规范。 七牛云有免费的使用额度&#xff0c;https://ww…

[附源码]SSM计算机毕业设计汽车租赁管理系统-JAVA

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Go学习之旅:包、变量和函数(DAY 1)

文章目录前引包、变量和函数1、包的概念和所用2、导出名或者导出函数3.1、函数参数声明方式&#xff08;一&#xff09;3.2、函数参数声明方式&#xff08;二&#xff09;4、函数返回值支持多值返回5、函数命名返回值6、变量声明7、变量的基础类型8、变量的默认值&#xff08;零…

pytorch案例代码-3

双向循环神经网络 双向循环神经网络在RNN/LSTM/GRU里都有。比如RNN cell&#xff0c;只是把h0和x1传入做线性变换产生h1继续传入同一个cell做线性变换&#xff0c;线性变换的W和b共享&#xff0c;沿着这个方向就把所有隐层和最后的输出算出来了。 那么其中的每个结点&#xff0…

android-apk解包打包

title: android-apk解包打包 categories: Android tags: [android, 加壳] date: 2022-09-28 10:29:51 comments: false mathjax: true toc: true android-apk解包打包, 以下所有操作都需要在配置好 java 环境下进行 前篇 android apk解包和打包 - https://blog.csdn.net/u0114…

(十五)Spring之面向切面编程AOP

文章目录基础环境AOP介绍AOP的七大术语切点表达式Spring的AOP的使用环境准备基于AspectJ的AOP注解式开发通知类型前置通知Before后置通知AfterReturning环绕通知Around异常通知AfterThrowing最终通知After关于JoinPoint切面的先后顺序通用切点表达式全注解式开发AOP基于XML配置…

9、前端笔记-CSS-CSS三大特性

三大特性&#xff1a;层叠性、继承性、优先级 1、层叠性&#xff08;覆盖性&#xff09; 给相同的选择器设置相同的样式&#xff0c;此时一个样式会覆盖&#xff08;层叠&#xff09;其他冲突的样式。 层叠性原则&#xff1a; 同一选择器&#xff0c;样式冲突&#xff0c;遵…

【SpringBoot】MVC配置解决跨域但仍然存在跨域

文章目录1. 跨域问题出现与解决1. 跨域问题出现与解决 检查SpringBoot中的MVC配置。 public void addCorsMappings(CorsRegistry registry) {//允许跨域访问资源定义registry.addMapping("/**")//(只允许本地的指定端口访问)允许所有.allowedOrigins("*")…

数据结构之线性表中的单链表【详解】

文章目录前言&#xff1a;一、单链表1.单链表和顺序表的优缺点2.单链表的概念和学习3.单链表的各个接口的实现&#xff08;详解每一步&#xff09;3.1.先铺垫一下大致的思路3.2.然后这边我们看一下我们大致要实现的函数有哪些3.3.接下来我们就开始实现这些代码&#xff0c;并且…