QUEUE

1. 优先级队列

1.1. LC 2182 构造限制重复的字符串

  1. 大根堆pq存储现有的字符种类
  2. 哈希表cnt存储每种字符的数量
  3. 每次弹出一种字符,直至没有字符可用
    1. 如果限制次数没被用完,使用,更新哈希表,剩余次数-1,把当前字符放回去
    2. 如果限制次数用完
      1. 如果此时没有另外的字符,结束
      2. 如果有另外的字符,弹出,使用,更新哈希表,剩余次数复位,把这两种字符全塞回去。
import java.util.Comparator;
import java.util.PriorityQueue;class Solution {public String repeatLimitedString(String s, int repeatLimit) {char[] ch = s.toCharArray();int[] cnt = new int[26];PriorityQueue<Character> pq = new PriorityQueue<>((o1, o2) -> -Character.compare(o1,o2));for (char c : ch) {int dis = c - 'a';if(cnt[dis]==0){pq.offer(c);}cnt[dis]++;}StringBuilder sb = new StringBuilder();int lim = repeatLimit;while(!pq.isEmpty()){Character f = pq.poll();if(lim>0){sb.append(f);lim--;cnt[f-'a']--;if(cnt[f-'a']!=0){pq.offer(f);}else{lim = repeatLimit;}}else{if(pq.isEmpty()){return sb.toString();}else{Character se = pq.poll();sb.append(se);cnt[se-'a']--;lim = repeatLimit;if(cnt[se-'a']!=0){pq.offer(se);}pq.offer(f);}}}return sb.toString();}
}

2. 单调队列

2.1. LC 862 和至少为K的最短子数组

子数组元素和显然要算前缀和。

维护一个单调增的单调队列。也就是如果队尾元素大于当前前缀和的话,就应该把队尾踢掉。这是因为:当后续前缀和查询队列中维护的前缀和时,如果当前前缀和与其之差≥k的话,那么与一个更小的前缀和之差也一定≥k。由于我们是正序的,所以踢走队尾的前缀和的索引一定更靠后。也就更接近日后查询时的索引。因此长度就更短。

对于查询,查询检查点直到查无可查为止。取最小值作为答案。

import java.util.ArrayDeque;class Solution {public int shortestSubarray(int[] nums, int k) {ArrayDeque<long[]> q = new ArrayDeque<>();long sum = 0;long ans = Long.MAX_VALUE;q.push(new long[]{0,-1});for (int i = 0; i < nums.length; i++) {sum += nums[i];while(!q.isEmpty() && sum-q.peekFirst()[0]>=k){ans = Math.min(ans,i-q.pollFirst()[1]);}while(!q.isEmpty() && sum<q.peekLast()[0]){q.pollLast();}q.add(new long[]{sum,i});}return ans==Long.MAX_VALUE?-1: (int) ans;}
}

之所以不用单调栈而是一个单调的双端队列,是因为栈没办法查询或操作栈底元素。我们想要最短区间,是肯定要查看之前最早的检查点的,也就是踢人的时候不能从队尾踢,队尾的前缀和要留给更后面的位置查询。栈满足不了这个需求。

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

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

相关文章

linux下USB抓包和分析流程

linux下USB抓包和分析流程 在windows下抓取usb包时可以通过wireshark安装时安装USBpcap来实现usb抓包&#xff0c;linux下如何操作呢&#xff1f; 是基于usbmon&#xff0c;本博客简单描述基于usbmon在linux系统上对通过usb口进行发送和接收的数据的抓包流程&#xff0c;分别描…

SCI期刊查询利器:影响因子和分区情况一站式查询

参考 本文仅作为学术分享,如果侵权,会删文处理 期刊的影响因子,最传统也最靠谱的方法就是去 Journal Citation Reports 官方平台上面查询,JCR 平台直接输入期刊名称检索,或者按照类别查找期刊:如果在校外没有访问JCR的权限,可以购买80图书馆的WOS套餐,仅需38元,不到一…

【51单片机系列】proteus仿真单片机的串口通信

本文参考&#xff1a;https://zhuanlan.zhihu.com/p/425809292。 在proteus之外使用串口软件和单片机通信。通过在proteus设计一个单片机接收PC发送的数据&#xff0c;并将接收的数据发送出去&#xff0c;利用软件【Configure Virtual Serial Port Driver】创建一对虚拟串口&am…

大疆Mid360雷达使用教程总结

大疆Mid360雷达使用教程总结 Reference: https://github.com/Livox-SDK/livox_ros_driver2 1. 下载编译安装Livox-SDK2 Reference: https://github.com/Livox-SDK/Livox-SDK2/blob/master/README.md 下载编译安装Livox-SDK2&#xff1a; git clone https://github.com/L…

java实现连接远程服务器,并可以执行shell命令

你可以使用Java中的SSH库来连接远程服务器并执行shell命令。下面是一个简单的示例代码&#xff1a; import com.jcraft.jsch.*;public class SSHExample {public static void main(String[] args) {String host "your_host";String username "your_username&…

如何编译Typescript文件?

要编译 TypeScript 文件&#xff0c;需要先安装 TypeScript 编译器。可以使用 npm 包管理器全局安装 TypeScript&#xff1a; npm install -g typescript安装完成后&#xff0c;可以使用以下命令来编译 TypeScript 文件&#xff1a; tsc filename.ts其中&#xff0c;filename…

Linux指令权限知识点总结

目录 周边知识 基础指令思维导图 权限思维导图 周边知识 大多数后端操作系统都是Linux操作系统操作系统是管理软件和硬件的软件Linux是一款操作系统Linux分为技术版本和商业版本Linux的文件是以多叉树的形式构建隐藏文件 . 和 ...可以表示当前路径。可以形成可执行文件&a…

关于ElasticSearch,你应该知道的

一、集群规划优化实践 1、基于目标数据量规划集群 在业务初期&#xff0c;经常被问到的问题&#xff0c;要几个节点的集群&#xff0c;内存、CPU要多大&#xff0c;要不要SSD&#xff1f; 最主要的考虑点是&#xff1a;你的目标存储数据量是多大&#xff1f;可以针对目标数据…

用LED数码显示器循环显示数字0~9

#include<reg51.h> // 包含51单片机寄存器定义的头文件 /************************************************** 函数功能&#xff1a;延时函数&#xff0c;延时一段时间 ***************************************************/ void delay(void) { unsigned …

Webpack5入门到原理3:基本配置

在开始使用 Webpack 之前&#xff0c;我们需要对 Webpack 的配置有一定的认识。 5 大核心概念 entry&#xff08;入口&#xff09; 指示 Webpack 从哪个文件开始打包 output&#xff08;输出&#xff09; 指示 Webpack 打包完的文件输出到哪里去&#xff0c;如何命名等 l…

【UE虚幻和Unity写实皮肤渲染逻辑知识点分享_第一篇】

写实皮肤渲染 写实皮肤渲染 写实皮肤渲染开个头写实皮肤渲染的技术点汇总1. f r \huge f_r f

phpmyadmin 创建服务器

phpmyadmin默认的服务器是localhost 访问setup&#xff0c;创建新的服务器 添加服务器信息 点击应用&#xff0c;服务器创建成功 下载配置文件config.inc.php&#xff0c;放到WWW目录下 可再次访问setup&#xff0c;发现已配置过了 访问登录页面&#xff0c;发现可选…

【mfc/VS2022】绘图工具设计-绘制基本图元2

接着&#xff1a;https://blog.csdn.net/qq_61814350/article/details/135609009?spm1001.2014.3001.5501 画圆 添加了bresenham法绘制圆的函数&#xff08;该算法详细步骤见专栏相关文章&#xff09;&#xff1a; void Bresenham_Circle(int xc, int yc, int r, CDC* pDC)…

第十一章 请求响应

第十一章 请求响应 1.概述2.请求-postman工具3.请求-简单参数&实体参数4.请求-数组集合参数5.请求-日期参数&JSON参数6.请求-路径参数7.响应-ResponseBody&统一响应结果8.响应-案例 1.概述 将前端发送的请求封装为HttpServletRequest对象 在通过HttpServletRespo…

OpenCV-Python(51):基于Haar特征分类器的面部检测

目标 学习了解Haar 特征分类器为基础的面部检测技术将面部检测扩展到眼部检测等。 基础 以Haar 特征分类器为基础的对象检测技术是一种非常有效的对象检测技术(2001 年Paul_Viola 和Michael_Jones 提出)。它是基于机器学习的,通过使用大量的正负样本图像训练得到一个cascade_…

【Linux取经路】初探进程地址空间

文章目录 一、历史问题回顾二、语言层面的地址空间2.1 验证 三、虚拟地址的引入3.1 初步解释这种现象——引入地址空间的概念3.2 再来粗粒度理解上面的现象 四、细节解释4.1 地址空间究竟是什么&#xff1f;4.2为什么要有地址空间4.3 页表4.3.1 CR3寄存器4.3.2 页表是由页表项组…

【Linux的基本指令】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言 1、ls 指令 2、 pwd命令 3、cd 指令 4、touch指令 5、mkdir指令&#xff08;重要&#xff09; 6、rmdir指令 && rm 指令&#xff08;重要&#xff09;…

前后端分离,仓储模式的医院安全(不良)事件报告系统

医院安全&#xff08;不良&#xff09;事件报告系统源码&#xff0c;PHP语言开发 医院不良事件上报系统&#xff0c;按照不良事件的管理部门不同&#xff0c;分为护理不良事件、药品不良反应事件、医技不良事件、院内感染事件、输血不良反应事件、器械不良事件、信息不良事件、…

strlen的使用和模拟实现

strlen的使用和模拟实现 首先&#xff0c;我们来看一下strlen的格式 size_t strlen(const char * str); 在这个strlen中&#xff0c;我们有几个需要注意的点&#xff1a; 1.strlen函数是用来测量字符串长度的&#xff08;在字符串当中在‘\0’之前的字符个数&#xff0c;\0不…

国产AI新篇章:书生·浦语2.0带来200K超长上下文解决方案

总览&#xff1a;大模型技术的快速演进 自2023年7月6日“书生浦语”&#xff08;InternLM&#xff09;在世界人工智能大会上正式开源以来&#xff0c;其在社区和业界的影响力日益扩大。在过去半年中&#xff0c;大模型技术体系经历了快速的演进&#xff0c;特别是100K级别的长…