附近最小(st表,线段树,单调队列三种解法)

问题描述
小蓝有一个序列 a[1],a[2],…,a[n]。

给定一个正整数 k,请问对于每一个 1 到 n 之间的序号 i,a[i−k],a[i−k+1],…,a[i+k] 这2k+1 个数中的最小值是多少?

当某个下标超过 1 到 n 的范围时,数不存在,求最小值时只取存在的那些值。

输入格式
输入的第一行包含一整数 n。

第二行包含 n 个整数,分别表示 a[1],a[2],…,a[n]。

第三行包含一个整数 k 。

输出格式
输出一行,包含 n 个整数,分别表示对于每个序号求得的最小值。

样例输入


5 2 7 4 3 

样例输出

2 2 2 3 3 

评测用例规模与约定
对于 30% 的评测用例,1<=n<=1000,1<=a[i]<=1000。

对于 50% 的评测用例,1<=n<=10000,1<=a[i]<=10000。

对于所有评测用例,1<=n<=1000000,1<=a[i]<=1000000。

运行限制
语言    最大运行时间    最大运行内存
C++    1s    256M
C    1s    256M
Java    3s    256M
Python3    12s    512M
PyPy3    12s    512M

语言最大运行时间最大运行内存
C++1s256M
C1s256M
Java3s256M
Python312s512M
PyPy312s512M
Go12s512M
JavaScript12s512M

一、ST表

参考文章:数据结构之ST表 详解_二维st表-CSDN博客

import java.util.*;public class Main {public static void main(String[] args) {Scanner scan = new Scanner(System.in);int n = scan.nextInt();int len = (int) (Math.log(n)/Math.log(2));int[][] st = new int[n+1][len+1];for (int i = 1; i <= n; i++) {st[i][0] = scan.nextInt();}for (int j = 1; j <= len; j++) {for (int i = 1; i + (1<<j) - 1 <= n; i++) {st[i][j] = Math.min(st[i][j-1], st[i+(1<<j-1)][j-1]);}}int k = scan.nextInt();for (int t = 1; t <= n; t++) {int start = Math.max(1, t-k);int end = Math.min(n, t+k);int j = (int) (Math.log(end-start+1)/Math.log(2));System.out.print(Math.min(st[start][j], st[end-(1<<j)+1][j])+" ");}}
}

二、线段树

参考文章:超详解线段树(浅显易懂,几乎涵盖所有线段树类型讲解,匠心之作,图文并茂)-CSDN博客

import java.util.*;public class Main {static int[] tree,a;public static void main(String[] args) {Scanner scan = new Scanner(System.in);int n = scan.nextInt();tree = new int[4*n+1];a = new int[n+1];for (int i = 1; i <= n; i++) {a[i] = scan.nextInt();}BuildTree(1, 1, n);int k = scan.nextInt();for (int i = 1; i <= n; i++) {int x = Math.max(i-k, 1);int y = Math.min(i+k, n);System.out.print(find(1, 1, n, x, y)+" ");}}public static void BuildTree(int id,int l,int r) {if (l == r) {tree[id] = a[l];return;}int mid = (l+r)/2;BuildTree(id*2, l, mid);BuildTree(id*2+1, mid+1, r);tree[id] = Math.min(tree[id*2], tree[id*2+1]);}public static int find(int id,int l,int r,int x,int y) {if (x <= l && y >= r) {return tree[id];}int mid = (l+r)/2;int res = Integer.MAX_VALUE;if (x <= mid) {res = Math.min(res, find(id*2, l, mid, x, y));}if (y > mid) {res = Math.min(res, find(id*2+1, mid+1, r, x, y));}return res;}
}

三、单调队列

参考文章:单调队列的学习 - 滑动窗口求最大/小值 (Leetcode 239, Sliding Window Maximum)_滑动窗口最小值-CSDN博客

import java.util.*;public class Main {public static void main(String[] args) {Scanner scan = new Scanner(System.in);int n = scan.nextInt();int[] min = new int[n+1];int[] a = new int[n+1];for (int i = 1; i <= n; i++) {a[i] = scan.nextInt();}int k = scan.nextInt();LinkedList<Integer> list = new LinkedList<Integer>();for (int i = 1; i <= k+1; i++) {while (!list.isEmpty() && i <= n && a[list.peekLast()] >= a[i]) {list.pollLast();}list.addLast(i);}min[1] = a[list.peekFirst()];for (int i = 2; i <= n; i++) {if (!list.isEmpty() && i-k > 0 && list.peekFirst() < i-k) {list.pollFirst();}while (!list.isEmpty() && i+k <= n && a[list.peekLast()] >= a[i+k]) {list.pollLast();}if (i+k <= n) {list.addLast(i+k);}min[i] = a[list.peekFirst()];}for (int i = 1; i <= n; i++) {System.out.print(min[i]+" ");}}
}

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

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

相关文章

力扣543. 二叉树的直径(java DFS解法)

Problem: 543. 二叉树的直径 文章目录 题目描述思路解题方法复杂度Code 题目描述 给你一棵二叉树的根节点&#xff0c;返回该树的 直径 。 二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。 两节点之间路径的 长度 由它们…

OGG实现Oracle19C到postgreSQL14的实时同步

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

人工智能算法

人工智能算法包括以下几类&#xff1a; 机器学习算法&#xff1a;这些算法利用数据和统计技术让计算机学习并改善其性能&#xff0c;包括监督学习、无监督学习和强化学习。 典型算法&#xff1a; 监督学习&#xff1a;线性回归、决策树、支持向量机&#xff08;SVM&#xff09;…

用户帐户限制(例如,时间限制)会阳止你登录。请与系统管理员或技术支持联系以获取帮助

出现的问题 用户帐户限制(例如&#xff0c;时间限制)会阳止你登录。请与系统管理员或技术支持联系以获取帮助 2.解决方法 使用WINR召唤出运行&#xff0c;然后输入secpol.msc,然后点击回车键&#xff0c;进入本地安全策略&#xff0c;在左边栏中找到本地策略&#xff0c;再…

TextCNN文本分类快速上手

这里写目录标题 TextCNN介绍&#xff1a;Docker从0安装Docker基于镜像安装容器打包操作&#xff08;生成镜像时使用的命令&#xff09;安装时命令 页面访问模型训练API访问性能测试其他查看显卡信息 TextCNN介绍&#xff1a; 1.支持语义识别和分类置信度输出。 2.训练速度快&…

HNU-公共钥匙盒

【问题描述】 有一个学校的老师共用N个教室&#xff0c;按照规定&#xff0c;所有的钥匙都必须放在公共钥匙盒里&#xff0c;老师不能带钥匙回家。每次老师上课前&#xff0c;都从公共钥匙盒里找到自己上课的教室的钥匙去开门&#xff0c;上完课后&#xff0c;再将钥匙放回到钥…

在动态时代引领软件领导地位

在职业追求领域&#xff0c;存在一种常见的误解&#xff0c;认为管理软件开发类似于骑自行车——一种静态技能&#xff0c;一旦获得&#xff0c;只需极少的调整就可以平稳地向前推进。然而&#xff0c;在快速发展的技术领域&#xff0c;这种比较不仅过于简单化&#xff0c;而且…

如何设计适合数字化转型需要的数据架构

现代组织需要一个模块化的数据架构来支持复杂的企业环境&#xff0c;同时为业务用户提供数据访问。以下是一些关键考虑因素。 一重视元数据的管理 数据架构不断发展以提供由元数据支持的数据自助服务 过去几十年来&#xff0c;数据分析架构最佳实践已经经历了多个时代&#…

linux服务器环境搭建(使用yum 安装mysql、jdk、redis)

一:yum的安装 1:下载yum安装包并解压 wget http://yum.baseurl.org/download/3.2/yum-3.2.28.tar.gz tar xvf yum-3.2.28.tar.gz 2.进入yum-3.2.28文件夹中进行安装,执行安装指令 cd yum-3.2.28 sudo apt install yum 3.更新版本 yum check-update yum update yum cle…

【算法思考记录】力扣2653. 滑动子数组的美丽值【C++,滑动窗口】

Problem: 2653. 滑动子数组的美丽值 滑动子数组的美丽值 问题描述 给定一个长度为 n 的整数数组 nums&#xff0c;我们需要计算每个长度为 k 的子数组的美丽值。 美丽值的定义如下&#xff1a;如果子数组中第 x 小的整数是负数&#xff0c;那么美丽值为第 x 小的数&#xff…

基于微博的信息热度评价与预测分析

摘 要 微博已成为时下非常热门的社交媒体平台&#xff0c;是一个庞大的关于信息分享和话题交流的平台&#xff0c;在人们线上社交活动中发挥着不可替代的作用&#xff0c;由于网络信息鱼龙混杂&#xff0c;所以本文通过了解微博的热度机制进而研究微博热度和预测微博的热门程度…

WebGL开发数据可视化应用

WebGL 是一种强大的图形渲染技术&#xff0c;用于在浏览器中创建高性能的交互式数据可视化应用。以下是开发这类应用的一般技术方案&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合作。 1.WebGL 框架&…

CRM实战:如何对商机阶段进行有效管理

对企业来说&#xff0c;管理客户的多个需求对于开发新的商机至关重要。一旦发现客户有多个需求&#xff0c;我们可以在客户信息表中建立相应数量的商机&#xff0c;这样有助于系统化地进行跟进&#xff0c;达到商机利用的最大化。那么&#xff0c;CRM系统如何进行企业的商机阶段…

SSL证书认证对搜索引擎有影响吗?

SSL证书认证对搜索引擎的影响是很大的。搜索引擎是用户获取网页信息的重要途径&#xff0c;它们会考虑网站的可信度和安全性等因素来为用户提供更好的搜索结果。而SSL证书认证可以提高网站的可信度和安全性&#xff0c;从而对搜索引擎优化和排名产生积极的影响。 首先&#xff…

C# 序列化+Base64加密、解密

一、保存到文件//将对象序列化成Json字符串(明文)string json System.Text.Json.JsonSerializer.Serialize(configModel);//将Json明文字符进行Base64加密byte[] jsonBytes Encoding.UTF8.GetBytes(json);string b64Str Convert.ToBase64String(jsonBytes);//写入文件File.W…

C语言二叉树的基本概念(一)

目录 二叉树 二叉树的分类&#xff08;目前只谈两种&#xff09; 满二叉树 完全二叉树 二叉树的性质&#xff08;其余的可以自己总结&#xff09; 选择练习 二叉树的存储结构 顺序存储方式 链式存储方式 二叉树 定义&#xff1a;二叉树是一种特殊的树状数据结构&…

前端漏洞--front(系统有user1/user1,admin1/admin1两个用户)

任务一&#xff1a;挖掘反射型XSS漏洞&#xff08;以弹窗test13&#xff09;证明 任务二&#xff1a;复现环境中的CSRF漏洞&#xff0c;设计表单&#xff0c;当管理员点击URL后自动将自己密码重置为&#xff1a;123456 任务三&#xff1a;复现环境中的JSON Hijacking漏洞&#…

电容、电感和电阻

一、电感 1&#xff09;图片 2&#xff09;作用 a&#xff09;储存容量 例如dcdc转换器的原理,将一个电压值转换成另外一个电压值 b&#xff09;选择信号 比如空气中弥漫着很多信号&#xff0c;我们应该怎么选取我们所需要的信号。 电感和电容可以看成一个电阻&#xff0c;当电…

35、AD模数转换DA数模转换

AD模数转换 main.c #include <REGX52.H> #include "Delay.h" #include "LCD1602.h" #include "XPT2046.h"unsigned int ADValue;void main(void) {LCD_Init();LCD_ShowString(1,1,"ADJ NTC GR");while(1){ADValueXPT2046_Re…

CRM管理系统:让你的业务运行更流畅

是客户关系管理系统的缩写。现代企业利用网络技术协调企业和客户之间在销售和服务上的对接&#xff0c;提升企业核心竞争力的一种手段。那么CRM管理系统一般包含哪些功能模块呢&#xff1f;今天小编为大家介绍一下。 一、好的CRM管理系统有哪些功能特性 1、有全方位的客户视图…