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

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


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.rhkb.cn/news/286060.html

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

相关文章

单目深度估计基础理论和论文学习总结

单目深度估计基础理论和论文学习总结 一、背景知识&#xff1a; 三维刚体运动的数学表示&#xff1a;旋转平移矩阵、旋转向量、欧拉角、四元数、轴角模型、齐次坐标、各种变换等 照相机模型&#xff1a;单目/双目模型&#xff0c;单目中的世界坐标系/相机坐标系/图像坐标系的…

一、初识 Web3

瑾以此系列文章&#xff0c;献给那些出于好奇并且想要学习这方面知识的开发者们 在多数时间里&#xff0c;我们对 web3 的理解是非常模糊的 就好比提及什么是 web1 以及 web2&#xff0c;相关概念的解释是&#xff1a; 1. 从 Web3 的开始 Web3&#xff0c;也被称为Web3.0&…

【排序算法】插入排序与选择排序详解

文章目录 &#x1f4dd;选择排序是什么&#xff1f;&#x1f320;选择排序思路&#x1f309; 直接选择排序&#x1f320;选择排序优化&#x1f320;优化方法&#x1f309;排序优化后问题 &#x1f320;选择排序效率特性 &#x1f309;插入排序&#x1f320;插入排序实现 &#…

shardingsphere-elastic-job-ui 管理界面安装

shardingsphere-elasticjob 从 3.0.0-alpha 版本开始&#xff0c;将console管理界面单独拆分出来 下载前需要 安装 maven 配置环境变量 安装 nodejs 配置环境变量 下载ui源码,安装 官方并未直接提供可执行的二进制文件,需要下载源码编译,目前发行版 3.0.2 https://github.com/…

修改网站源码,给电子商城的商品添加图片时商品id为0的原因

修改网站源码&#xff0c;给电子商城的商品添加图片时商品id为0的原因。花了几个小时查找原因。后来&#xff0c;由于PictureControl.class.php是复制CourseControl.class.php而来&#xff0c;于是对比了这两个文件&#xff0c;在CourseControl.class.php找到了不一样的关键几条…

探索AI大模型学习的未来发展与挑战

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;日常聊聊 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言 正文 AI大模型学习的理论基础 AI大模型的训练与优化 AI大模型在特定领域的应用 AI大模型学习的伦理与社会影响 未来发展趋势与挑…

T2I diffusion模型是零样本分类器笔记

1 tle Text-to-Image Diffusion Models are Zero-Shot Classifiers&#xff08;Kevin Clark, Priyank Jaini&#xff09;【NeurIPS Proceedings 2023】 2 Conclusion This study investigates diffusion models by proposing a method for evaluating them as zero-shot class…

基于nodejs+vue学生作业管理系统python-flask-django-php

他们不仅希望页面简单大方&#xff0c;还希望操作方便&#xff0c;可以快速锁定他们需要的线上管理方式。基于这种情况&#xff0c;我们需要这样一个界面简单大方、功能齐全的系统来解决用户问题&#xff0c;满足用户需求。 课题主要分为三大模块&#xff1a;即管理员模块和学生…

EDR下的线程安全

文章目录 前记进程断链回调执行纤程内存属性修改early birdMapping后记reference 前记 触发EDR远程线程扫描关键api&#xff1a;createprocess、createremotethread、void&#xff08;指针&#xff09;、createthread 为了更加的opsec&#xff0c;尽量采取别的方式执行恶意代…

第十节HarmonyOS 常用容器组件3-GridRow

1、描述 栅格容器组件&#xff0c;仅可以和栅格子组件&#xff08;GridCol&#xff09;在栅格布局场景中使用。 2、子组件 可以包含GridCol子组件。 3、接口 GridRow(options:{columns: number | GridRowColumnOption, gutter?: Length | GutterOption, Breakpoints?: B…

SpringBoot 3整合Elasticsearch 8

这里写自定义目录标题 版本说明spring boot POM依赖application.yml配置新建模型映射Repository简单测试完整项目文件目录结构windows下elasticsearch安装配置 版本说明 官网说明 本文使用最新的版本 springboot: 3.2.3 spring-data elasticsearch: 5.2.3 elasticsearch: 8.1…

jvm(虚拟机)运行时数据区域介绍

Java虚拟机&#xff08;JVM&#xff09;运行时数据区域是Java程序在运行过程中使用的内存区域&#xff0c;它主要包括以下几个部分&#xff1a; 程序计数器&#xff08;Program Counter Register&#xff09;&#xff1a; 程序计数器是一块较小的内存区域&#xff0c;是线程私有…

AI新工具 视频迁移升级中国水墨画风格2.0;新颖的视频编辑框架提示编辑,风格转移,身份操控都不在话下;提取多种风格人脸草图

✨ 1: DomoAI 升级中国水墨画风格2.0 DomoAI是一个多功能的AI视频处理工具&#xff0c;可以将视频转换成多种风格&#xff0c;包括日本动漫、3D卡通、漫画和像素风格等。用户只需上传原始视频&#xff0c;通过简单的操作就能实现风格转换&#xff0c;制作出具有个性的高质量视…

【C++】虚拟继承 组合

目录 一、虚拟继承 &#x1f31f;【非虚拟内存分布】 &#x1f31f;【虚拟继承内存分布】 &#x1f31f;【虚拟继承读取】 &#x1f31f;【练习检验】 &#x1f31f;【继承的总结和反思】 二、组合 &#x1f31f;【继承和组合】 &#x1f31f;【前言回顾】 上一篇文章我们…

Linux下对线程的认识+生产消费者模型+信号量

线程的概念 线程是进程内部中更加轻量化的一种执行流。线程是CPU调度的基本单位&#xff0c;而进程是承担系统资源的实体。就是说一个进程中可能会有多个线程&#xff0c;而在Linux内核中并没有真正重新的创建线程并重新进行资源分配&#xff0c;因为我们每个线程指向的资源都是…

PyQt:实现菜单栏的点击拖动效果

一、整体步骤 1.设计UI文件 2.调用显示 3.效果展示 二、设计UI文件 1.添加 Scroll Area控件&#xff0c;作为菜单栏的布置区域 2.设置 Scroll Area控件的属性 3.Scroll Area控件内放置 按钮控件 组成菜单栏 此处&#xff0c;放置了需要了6个按钮&#xff0c;并设置按钮的固…

三级数据库技术考点(详解!!)

1、 答疑:【解析】分布式数据库系统按不同层次提供的分布透明性有:分片透明性;②位置透明性;③局部映像透明性&#xff0c;位置透明性是指数据分片的分配位置对用户是透明的&#xff0c;用户编写程序时只需 要考虑数据分片情况&#xff0c;不需要了解各分片在各个场地的分配情…

ideaSSM 工厂效能管理系统bootstrap开发mysql数据库web结构java编程计算机网页源码maven项目

一、源码特点 idea 开发 SSM 工厂效能管理系统是一套完善的信息管理系统&#xff0c;结合SSM框架和bootstrap完成本系统&#xff0c;对理解JSP java编程开发语言有帮助系统采用SSM框架&#xff08;MVC模式开发&#xff09;&#xff0c;系统具有完整的源代码和数据库&#xff…

MySQL之基本操作与用户授权

一 基本操作 1 SQL分类 数据库&#xff1a;database 表&#xff1a;table&#xff0c;行&#xff1a;row 列&#xff1a;column 索引&#xff1a;index 视图&#xff1a;view 存储过程&#xff1a;procedure 存储函数&#xff1a;function 触发器&#xff1a;trigger 事…

34-Java传输对象模式 ( Transfer Object Pattern )

Java传输对象模式 实现范例 传输对象模式&#xff08;Transfer Object Pattern&#xff09;用于从客户端向服务器一次性传递带有多个属性的数据传输对象也被称为数值对象&#xff0c;没有任何行为传输对象是一个具有 getter/setter 方法的简单的 POJO 类&#xff0c;它是可序列…