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

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


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).总结

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

试题链接

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

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

相关文章

软件测试经验与教训

大概在18年的时候&#xff0c;就看过《软件测试经验与教训》的纸制版&#xff0c;里面的一些观点深刻的影响了我&#xff0c;也影响了后来我对测试的思考。最近又一次快速阅读了电子版&#xff0c;还是收获满满。下面精选出10条&#xff0c;和大家分享。 一、测试人员是项目的…

混合云构建-使用 Azure ExpressRoute 建立从本地到 Azure 虚拟网络的专用连接

如果有大量业务数据需要在本地数据中心和azure私有网络进行传输&#xff0c;同时保证带宽和时延的情况需要使用 ExpressRoute 设置从本地网络到 Azure 中的虚拟网络的专用连接。以下是实操步骤供参考&#xff1a; 一、创建和预配 ExpressRoute 线路 登录 Azure 门户。 在页面…

YOLOv9解读

论文地址&#xff1a;https://arxiv.org/abs/2402.13616 Github地址&#xff1a;https://github.com/WongKinYiu/yolov9 一、引言 作者认为当前深度学习方法忽略了一个事实&#xff0c;即当输入数据经过逐层特征提取和空间变换时&#xff0c;大量信息将会丢失。本文基于深入研…

RK3568驱动指南|第十三篇 输入子系统-第145 章 输入子系统上报数据格式分析

瑞芯微RK3568芯片是一款定位中高端的通用型SOC&#xff0c;采用22nm制程工艺&#xff0c;搭载一颗四核Cortex-A55处理器和Mali G52 2EE 图形处理器。RK3568 支持4K 解码和 1080P 编码&#xff0c;支持SATA/PCIE/USB3.0 外围接口。RK3568内置独立NPU&#xff0c;可用于轻量级人工…

PostgreSQL中控制文件的解析与恢复

最近遇到有人问起PG中控制文件的一些使用问题,总结了一下。 1、PG控制文件简介 1.1、存储的位置 它的路径位于: 相关信息,可以用命令pg_controldata得到: [10:41:27-postgres@centos2:/var/lib/pgsql/14/data/global]$ pg_controldata -D $PGDATA pg_control version …

深度学习十大算法之长短时记忆网络(LSTM)

一、长短时记忆网络&#xff08;LSTM&#xff09;的基本概念 长短时记忆网络&#xff08;LSTM&#xff09;是一种特殊类型的循环神经网络&#xff08;RNN&#xff09;&#xff0c;主要用于处理和预测序列数据的任务。LSTM由Hochreiter和Schmidhuber于1997年提出&#xff0c;其…

自动驾驶建图--道路边缘生成方案探讨

自动驾驶建图–道路边缘生成方案探讨 一、背景 对于自动驾驶来说&#xff0c;建图是必不可少的&#xff0c;目前主流厂商技术都在从HD到"无图"进行过渡筹备中&#xff0c;不过想要最终实现真正的"无图"还是有很长的一段路要走。 对于建图来说&#xff0c;…

二.寄存器

1. 2. 例如&#xff1a;h即为high&#xff08;高位&#xff09;&#xff0c;l即为low&#xff08;低位&#xff09; 3.一个字是两个字节 4.在写一条汇编指令或一个寄存器的名称时不区分大小写。 5.al&#xff0c;ah&#xff0c;ax在接受汇编指令时&#xff0c;并不相等&…

【计算机毕业设计】基于ssm038框架的网上招聘系统的设计与实现lw7

基于ssm038框架的网上招聘系统的设计与实现lw7&#xff1a; 本课题是基于ssm框架&#xff08;springMVC,spring,mybatis)的招聘系统&#xff0c;是标准的MVC模式&#xff0c;将系统分为表现层、controller层、service层、DAO层四层&#xff0c;使用spring MVC负责请求的转发和视…

在pycharm中运行程序时总是以tests方式运行

## 问题描述 前两天在使用python写机器学习的算法时&#xff0c;有一个程序一直以Python tests的方式运行&#xff0c;并且一直运行失败&#xff0c;截图如下&#xff1a; 解决方法 到设置中&#xff1a;File->Settings->Tools->Python integrated Tools 文件->…

DBO优化朴素贝叶斯分类预测(matlab代码)

DBO-朴素贝叶斯分类预测matlab代码 蜣螂优化算法(Dung Beetle Optimizer, DBO)是一种新型的群智能优化算法&#xff0c;在2022年底提出&#xff0c;主要是受蜣螂的的滚球、跳舞、觅食、偷窃和繁殖行为的启发。 数据为Excel分类数据集数据。 数据集划分为训练集、验证集、测试…

基于springboot+vue的教学改革项目管理系统(源码+论文)

作者主页&#xff1a;Java码库 主营内容&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app等设计与开发。 收藏点赞不迷路 关注作者有好处 文末获取源码 技术选型 【后端】&#xff1a;Java 【框架】&#xff1a;spring…

vs2019新建Qt工程中双击 .ui 文件无法打开

vs2019 中创建的 Qt 工程&#xff0c;在使用的过程中&#xff0c;经常会有&#xff1a;双击 .ui 文件&#xff0c;闪退的情况&#xff0c;也即 .ui 文件无法打开&#xff01; 针对该问题的详细解决步骤如下&#xff1a; 1、右击该 .ui 文件&#xff0c;选择“打开方式” 2、…

6、kubenetes 卷

1、什么是卷 在某些场景下&#xff0c;我们可能希望新的容器可以在之前容器结束的位 置继续运⾏&#xff0c;⽐如在物理机上重启进程。可能不需要&#xff08;或者不想要&#xff09; 整个⽂件系统被持久化&#xff0c;但又希望能保存实际数据的⽬录。 Kubernetes通过定义存储…

指尖论文能用吗 #经验分享#微信

指尖论文是一款非常好用、靠谱、方便的论文写作、查重降重工具。无论是学生还是学者&#xff0c;都可以通过指尖论文轻松完成论文写作任务。指尖论文提供了丰富的论文模板和参考资料&#xff0c;让论文写作变得更加简单和高效。 指尖论文还内置了强大的查重和降重功能&#xff…

Centos上安装Harbor并使用

harbor的安装与使用 Harbor介绍安装前的准备工作为Harbor自签发证书安装Harbor安装docker开启包转发功能和修改内核参数安装harbor扩展 Harbor 图像化界面使用说明测试使用harbor私有镜像仓库从harbor仓库下载镜像 Harbor介绍 容器应用的开发和运行离不开可靠的 镜像管理&…

2024年阿里云服务器优惠价格表_一张表清晰明了

2024年腾讯云服务器优惠价格表&#xff0c;一张表整理阿里云服务器最新报价&#xff0c;阿里云服务器网整理云服务器ECS和轻量应用服务器详细CPU内存、公网带宽和系统盘详细配置报价单&#xff0c;大家也可以直接移步到阿里云CLUB中心查看 aliyun.club 当前最新的云服务器优惠券…

Mac上玩《赛博朋克2077》mac电脑怎么玩这个游戏

X用户crushovitz_b最近发现&#xff0c;在《赛博朋克2077》游戏主菜单页面&#xff0c;将鼠标停在版本号选项卡上面足够长时间&#xff0c;就会发现游戏当前的版本号由2.12变为了2.0.77&#xff0c;这是对游戏标题2077的致敬彩蛋。 《赛博朋克2077》的叙事总监兼续集副总监Pawe…

C语言实现三子棋强化学习算法AI,思路详解+完整代码

写个三子棋的强化学习AI玩玩。写这玩意只需要有一点C语言基础就可以了&#xff0c;至于AI部分&#xff0c;也是很好理解的。 三子棋 在3*3的棋盘中&#xff0c;先手方画O&#xff0c;后手方画X&#xff0c;连成3个就赢了。事实上&#xff0c;只需要很简单的试验&#xff0c;你…

大学期末考试搜题软件?这4款足够解决问题 #知识分享#笔记#职场发展

当代大学生面临着繁重的学业压力和海量的知识点&#xff0c;如何高效地进行学习和搜题成了他们关注的焦点。幸运的是&#xff0c;随着科技的不断进步&#xff0c;我们有越来越多的日常搜题和学习软件可以帮助我们更好地应对这些挑战。在本文中&#xff0c;我将为大家介绍10款备…