蓝桥杯算法心得——附近最小(优先队列+滑动窗口)

大家好,我是晴天学长,这题可以用贪心优先队列和滑动窗口来写,需要的小伙伴可以关注支持一下哦!后续会继续更新的。💪💪💪


1) .附近最小

在这里插入图片描述
问题描述
小蓝有—个序列a[1], a[2],...,a[n]。
给定—个正整数k,请问对于每一个1到n之间的序号i,a[i- k], a[i-k +1],..., ai+剐]这2k +1个数中的最小值是多少?
当某个下标超过1到n的范围时,数不存在,求最小值时只取存在的那些值。
输入格式
输入的第一行包含一整数n。
第二行包含n个整数,分别表示a[1], a[2],..., a[n]。
第三行包含一个整数k。
输出格式
输出一行,包含n个整数,分别表示对于每个序号求得的最小值。
样例输入
5
5 27 4 3
样例输出
2 2 2 3 3


2) .算法思路

附近最小(优先队列)
用滑动窗口和优先队列写
1.用队列
1.接收数据
2.优先队列
int【】 第一个存大小,第二个存位置
3.先存数据进去

开始遍历
1.优先队列都要压进去
2.前进(3种)
1.最小值过了
2.更新最小值
3.最小值不变

附近最小(滑动窗口)

1.接收数据
2.找出最小的(k的大小)
并记录下标位置

然后开始遍历用l,r表示
1.进来的要比最小值都要小(r++)
或者不变
2.当最小值的下标小于时,需要重新遍历,确定最小值(l++)

3).算法步骤

方法一(优先队列)
1.读取输入的字符串并将其分割为字符串数组。
2.将第一个字符串转换为整数n,表示数组的长度。
3.创建一个长度为n的整数数组N,并将第二个字符串数组中的元素转换为整数并赋值给N数组。
4.将第三个字符串转换为整数k,表示附近的最小元素的个数。
5.创建一个优先队列queue,使用lambda表达式定义比较器,按照元素的值进行升序排序。
6.遍历数组N的前k+1个元素,将其加入优先队列queue中,每个元素是一个数组,包含元素值和元素的索引。
7.创建一个长度为n的整数数组result,用于存储每个位置的附近最小元素。
8.遍历数组result的每个位置i:
a. 如果i不大于n-k,将N[i+k]和i+k加入优先队列queue中。
b. 当队列不为空且队首元素的索引小于i-k时,从队列中移除队首元素。
c. 将队首元素的值赋给result[i]。
9.遍历数组result,输出每个元素的值。
10.完成算法。
方法二(滑动窗口)
创建一个静态整数数组a和一个静态整数min,用于存储输入数据和当前窗口内的最小值。
使用Scanner类读取输入的整数n,表示数组的长度。
创建一个长度为n的整数数组a,并使用循环将输入的整数赋值给数组a。
使用Scanner类读取输入的整数k,表示滑动窗口的大小。
调用findMin方法,传入参数0和k,找到初始窗口内的最小值。
使用循环遍历数组a的每个元素:
a. 计算当前窗口的左边界l,最小值的下标不小于l。
b. 计算当前窗口的右边界r,最小值的下标不大于r。
c. 如果当前窗口的最小值不大于min,则更新min为当前窗口的最小值。
d. 否则,如果当前窗口的左边界大于0且a[l-1]等于min,则调用findMin方法,传入参数l和r,重新找到窗口内的最小值。
e. 输出当前窗口的最小值min。
完成算法。


4). 代码实例

方法一:优先队列
package LanQiaoTest;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.PriorityQueue;

public class 附近最小 {
	static BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
	static String[] strings;

	public static void main(String[] args) throws IOException {
		strings = in.readLine().split(" ");
		int n = Integer.parseInt(strings[0]);
		int[] N = new int [n];
		strings = in.readLine().split(" ");
		for (int i = 0; i < N.length; i++) {
			N[i] = Integer.parseInt(strings[i]);
		}
		strings = in.readLine().split(" ");
		int k = Integer.parseInt(strings[0]);
		PriorityQueue<int[]> queue = new PriorityQueue<>((o1,o2)->(o1[0]-o2[0]));
		for (int i = 0; i <= k; i++) {
			queue.add(new int[] {N[i],i});
		}
		int[] result = new int[n];
		for (int i = 0; i < result.length; i++) {
				if(!(i>=n-k)) {
					queue.add(new int[] {N[i+k],i+k});
				}
				while (!queue.isEmpty()&&queue.peek()[1]<i-k) {
					queue.poll();
				}
				result[i] = queue.peek()[0];
			
		}
		for (int i = 0; i < result.length; i++) {
			System.out.print(result[i]+" ");
		}
	}

}


方法二:滑动窗口


import java.util.Scanner;

public class Main {
    static int[] a;
    static int min = Integer.MAX_VALUE;

    public static void main(String[] args) {
      Scanner scanner = new Scanner(System.in);
      int n = scanner.nextInt();
      a = new int[n];
      for (int i = 0; i < n; i++) {
		a[i] = scanner.nextInt();
	}
      int k = scanner.nextInt();
      scanner.close();
      findMin(0, k);
      for (int i = 0; i < n; i++) {
		int l = Math.max(i-k, 0);
		int r = Math.min(i+k, n-1);
		if (a[r]<=min) {
			min = a[r];
		}else {
			if (i-k>0&&a[l-1]==min) {
				findMin(l, r);
			}
		}
		System.out.print(min+" ");
	}
 }


    static void findMin(int start, int end) {
        min = Integer.MAX_VALUE;
        for (int i = start; i <= end; i++) {
            min = Math.min(min, a[i]);
        }
    }
}

4).总结

  • 优先队列的使用和边界的判定。

试题链接

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【MySQL】7. 基本查询(create / retrieve)

表的增查 CRUD : Create(创建), Retrieve(读取)&#xff0c;Update(更新)&#xff0c;Delete&#xff08;删除&#xff09; 1. Create 语法&#xff1a; INSERT [INTO] table_name[(column [, column] ...)] VALUES (value_list) [, (value_list)] ...value_list: value, […

【办公类-16-07-07】“2023下学期 大班户外游戏2(有场地和无场地版,每天不同场地)”(python 排班表系列)

作品展示 背景需求&#xff1a; 2024年2月教务组发放的是“每周五天内容相同&#xff0c;两周10天内容相同”的户外游戏安排 【办公类-16-07-05】合并版“2023下学期 大班户外游戏&#xff08;有场地和无场地版&#xff0c;两周一次&#xff09;”&#xff08;python 排班表系…

探秘国内ip切换手机软件,全是干货,火速Get!

随着互联网的普及和深入&#xff0c;人们在网络空间中的活动也变得越来越频繁。然而&#xff0c;在享受网络便利的同时&#xff0c;个人隐私保护和数据安全问题愈发突出。国内IP切换手机软件因其功能多样、易用性强大而备受关注。这类软件可以帮助用户切换IP地址&#xff0c;隐…

百度智能云+SpringBoot=AI对话【人工智能】

百度智能云SpringBootAI对话【人工智能】 前言版权推荐百度智能云SpringBootAI对话【人工智能】效果演示登录AI对话 项目结构后端开发pom和propertiessql_table和entitydao和mapperservice和implconfig和utilLoginController和ChatController 前端开发css和jslogin.html和chat.…

Java newInstance方法学习

用newInstance与用new是有区别的&#xff0c;区别在于创建对象的方式不一样&#xff0c;前者是使用类加载机制&#xff1b; newInstance方法要求该 Class 对应类有无参构造方法&#xff1b; 执行 newInstance()方法实际上就是使用对应类的无参构造方法来创建该类的实例&#x…

【prometheus-operator】k8s监控集群外redis

1、部署exporter GitHub - oliver006/redis_exporter: Prometheus Exporter for Redis Metrics. Supports Redis 2.x, 3.x, 4.x, 5.x, 6.x, and 7.x redis_exporter-v1.57.0.linux-386.tar.gz # 解压 tar -zxvf redis_exporter-v1.57.0.linux-386.tar.gz # 启动 nohup ./redi…

流畅的 Python 第二版(GPT 重译)(三)

第五章&#xff1a;数据类构建器 数据类就像孩子一样。它们作为一个起点是可以的&#xff0c;但要作为一个成熟的对象参与&#xff0c;它们需要承担一些责任。 马丁福勒和肯特贝克 Python 提供了几种构建简单类的方法&#xff0c;这些类只是一组字段&#xff0c;几乎没有额外功…

软件管理rpm与yum

源代码包下载 Compare, Download & Develop Open Source & Business Software - SourceForgehttps://sourceforge.net/ rpm包下载 Welcome to the RPM repository on fr2.rpmfind.nethttp://rpmfind.net/linux/RPM/ 软件包管理 1.rpm包管理: 1)查询: 安装…

蓝桥杯Python B组练习——完美的代价

一、题目 问题描述   回文串&#xff0c;是一种特殊的字符串&#xff0c;它从左往右读和从右往左读是一样的。小龙龙认为回文串才是完美的。现在给你一个串&#xff0c;它不一定是回文的&#xff0c;请你计算最少的交换次数使得该串变成一个完美的回文串。   交换的定义是…

计算机网络相关

OSI七层模型 各层功能&#xff1a; TCP/IP四层模型 应用层 传输层 网络层 网络接口层 访问一个URL的全过程 在浏览器中输入指定网页的 URL。 浏览器通过 DNS 协议&#xff0c;获取域名对应的 IP 地址。 浏览器根据 IP 地址和端口号&#xff0c;向目标服务器发起一个 TCP…

电影aac是什么意思?如何播放、转换、编辑aac?

"电影AAC"这个术语可能是指电影中的音频编码格式。AAC&#xff08;Advanced Audio Coding&#xff09;是一种常见的音频编码格式&#xff0c;通常用于压缩音频文件&#xff0c;以在保持高质量的同时减小文件大小。在电影中&#xff0c;AAC格式的音频通常用于提供高质…

webpack5零基础入门-13生产模式

1.生产模式介绍 生产模式是开发完成代码后&#xff0c;我们需要得到代码将来部署上线。 这个模式下我们主要对代码进行优化&#xff0c;让其运行性能更好。 优化主要从两个角度出发: 优化代码运行性能优化代码打包速度 2.生产模式准备 我们分别准备两个配置文件来放不同的…

【RAG实践】基于 LlamaIndex 和Qwen1.5搭建基于本地知识库的问答机器人

什么是RAG LLM会产生误导性的 “幻觉”&#xff0c;依赖的信息可能过时&#xff0c;处理特定知识时效率不高&#xff0c;缺乏专业领域的深度洞察&#xff0c;同时在推理能力上也有所欠缺。 正是在这样的背景下&#xff0c;检索增强生成技术&#xff08;Retrieval-Augmented G…

PC 端 LVGL 模拟器之 Visual Studio

LVGL&#xff08;Light and Versatile Graphics Library&#xff09;是一个轻量化的、开源的、在嵌入式系统中广泛使用的图形库&#xff0c;它提供了一套丰富的控件和组件&#xff0c;只需要少量的内存和计算资源&#xff0c;使得在资源受限的设备上创建高端的图形界面成为可能…

pycorrector检测OCR错字实践

参考&#xff1a;https://github.com/shibing624/pycorrector/tree/master/examples/macbert stopwords.txt 添加专业停用词&#xff0c;避免错误 设置自定义词典&#xff0c;避免将正确的词错误检测成错误的词 from pycorrector import Corrector m Corrector() m.set_cus…

Mysql——基础命令集合

目录 前期准备 先登录数据库 一、管理数据库 1.数据表结构解析 2.常用数据类型 3.适用所有类型的修饰符 4.使用数值型的修饰符 二、SQL语句 1.SQL语言分类 三、Mysql——Create,Show,Describe,Drop 1.创建数据库 2.查看数据库 3.切换数据库 4.创建数据表 5.查看…

ELK快速搭建图文详细步骤

目录 一、下载地址二、安装docker-compose(已安装则跳过)三、初始化ELK1. 赋予/setup/entrypoint.sh执行权限2. 初始化 docker-elk 所需的 Elasticsearch 用户和组3. 重置默认用户的密码4. 替换配置文件中的用户名和密码5. 重启 Logstash 和 Kibana&#xff0c;使用新密码重新连…

改进粒子群优化算法||粒子群算法变体||Improved particle swarm optimization algorithm

粒子群算法&#xff08;Particle Swarm Optimization&#xff0c;PSO&#xff09;是一种基于群体智能的优化算法&#xff0c;其思想来源于鸟群寻食和鱼群捕食等自然现象。PSO算法通过模拟群体智能的行为&#xff0c;以一种启发式的方式寻找最优解&#xff0c;因此具有全局搜索能…

【FAQ】BSV区块链代码库常见问题解答

​​发表时间&#xff1a;2024年2月27日 BSV区块链协会上线了JavaScript和TypeScript SDK&#xff08;即“标准开发工具包”&#xff09;。TypeScript SDK旨在为开发者提供新版统一核心代码库&#xff0c;让开发者可以在BSV区块链上便捷地进行开发&#xff0c;尤其是开发那些可…

C语言中的联合和枚举(未完)

1、联合体 联合体类型的声明 像结构体⼀样&#xff0c;联合体也是由⼀个或者多个成员构成&#xff0c;这些成员可以不同的类型。但是编译器只为最⼤的成员分配⾜够的内存空间。联合体的特点是所有成员共⽤同⼀块内存空间。所以联合体也叫&#xff1a;共⽤体。因为所有变量公用…