【算法练习】leetcode算法题合集之栈和队列篇

普通栈

LeetCode20 有效的括号

LeetCode20 有效的括号

定义一个辅助map,判断字符串的字符是否在]})中。一旦是右括号就要弹出元素,判断匹配。

class Solution {public boolean isValid(String s) {if (s.length() % 2 == 1) {return false;}Map<Character, Character> pairs = new HashMap<>();pairs.put(')', '(');pairs.put(']', '[');pairs.put('}', '{');Stack<Character> stack = new Stack<>();for (int i = 0; i < s.length(); i++) {if (pairs.containsKey(s.charAt(i))) {if (stack.isEmpty() || pairs.get(s.charAt(i)) != stack.peek()) {return false;}stack.pop();} else {stack.push(s.charAt(i));}}if (!stack.isEmpty()) {return false;}return true;}
}

LeetCode155. 最小栈

LeetCode155. 最小栈

使用栈记录最小的元素。

class MinStack {private Stack<Integer> stack;private Stack<Integer> minStack;public MinStack() {stack = new Stack<>();minStack = new Stack<>();}public void push(int val) {stack.push(val);if (minStack.isEmpty() || minStack.peek() >= val) {minStack.push(val);}}public void pop() {Integer pop = stack.pop();if (pop.equals(minStack.peek())) {minStack.pop();}}public int top() {return stack.peek();}public int getMin() {return minStack.peek();}
}

LeetCode232. 用栈实现队列

LeetCode232. 用栈实现队列

使用出栈和入栈。

出栈为空的情况下,才去调用入栈的数据。[1,2]存到入栈,出栈是[2,1],如果1这时候出去了,2保留在里面,2应该是下一个出去的元素。

class MyQueue {private Stack<Integer> inStack;private Stack<Integer> outStack;public MyQueue() {inStack = new Stack<>();outStack = new Stack<>();}public void push(int x) {inStack.push(x);}public int pop() {if (outStack.isEmpty()) {while (!inStack.isEmpty()) {outStack.push(inStack.pop());}}return outStack.pop();}public int peek() {if (outStack.isEmpty()) {while (!inStack.isEmpty()) {outStack.push(inStack.pop());}}return outStack.peek();}public boolean empty() {return inStack.isEmpty() && outStack.isEmpty();}
}

LeetCode225. 用队列实现栈

LeetCode225. 用队列实现栈

使用入队和出队,入队接收第一个元素(即将出队),把出队的元素移动到入队中,再换成出队。保证入队一直为空。

class MyStack {private Queue<Integer> inQueue;private Queue<Integer> outQueue;public MyStack() {inQueue = new LinkedList<>();outQueue = new LinkedList<>();}public void push(int x) {inQueue.offer(x);while (!outQueue.isEmpty()) {inQueue.offer(outQueue.poll());}Queue<Integer> tmp = inQueue;inQueue = outQueue;outQueue = tmp;}public int pop() {return outQueue.poll();}public int top() {return outQueue.peek();}public boolean empty() {return outQueue.isEmpty();}
}

一个队列。把原先队列中的元素添加到新来的元素后面。

class MyStack {private Queue<Integer> queue;public MyStack() {queue = new LinkedList<>();}public void push(int x) {int size = queue.size();queue.offer(x);for (int i = 0; i < size; i++) {queue.offer(queue.poll());}}public int pop() {return queue.poll();}public int top() {return queue.peek();}public boolean empty() {return queue.isEmpty();}
}

LeetCode394. 字符串解码(**)

LeetCode394. 字符串解码

字符串的拼接最好使用队列,将元素从集合中获取到用的是栈(获取后面的元素)

队列中有b,c,从栈中获取到的先是c,后是b,这是栈,会把字符串的顺序给弄反。

队列中存在jk,b,c,应该是jkbc拼接的,但是从栈中取元素是c,b,jk,需要先将集合的元素给弄反,再去拼接。

linkedList,addLast和push操作,是不一样的。

class Solution {public String decodeString(String s) {LinkedList<String> linkedList = new LinkedList<>();int index = 0;while (index < s.length()) {char c = s.charAt(index);if (Character.isDigit(c)) {StringBuilder sb = new StringBuilder();while (Character.isDigit(s.charAt(index))) {sb.append(s.charAt(index));index++;}linkedList.add(sb.toString());} else if (Character.isLetter(c) || c == '[') {linkedList.add(String.valueOf(c));index++;} else {index++;List<String> list = new ArrayList<>();// bc --> 先加入c,后添加bwhile (!linkedList.peekLast().equals("[")) {list.add(linkedList.pollLast());}Collections.reverse(list);String string = list.stream().collect(Collectors.joining());linkedList.pollLast();int repeatTime = Integer.parseInt(linkedList.pollLast());StringBuilder res = new StringBuilder();for (int i = 0; i < repeatTime; i++) {res.append(string);}linkedList.add(res.toString());}}StringBuilder res = new StringBuilder();while (!linkedList.isEmpty()) {res.append(linkedList.poll());}return res.toString();}
}

单调栈

LeetCode739. 每日温度

栈中的元素是单调递减的,找到一个大的元素就将栈中的元素弹出

26,24,22…遇到25的时候就可以记录24和22的温度在几天后有升高。

class Solution {public int[] dailyTemperatures(int[] temperatures) {int[] res = new int[temperatures.length];Stack<Integer> stack = new Stack<>();stack.push(0);// 26,24...递减的结构for (int i = 1; i < temperatures.length; i++) {if (temperatures[stack.peek()] < temperatures[i]) {while (!stack.isEmpty() && temperatures[stack.peek()] < temperatures[i]) {Integer pop = stack.pop();res[pop] = i - pop;}stack.push(i);} else {stack.push(i);}}return res;}
}

LeetCode42. 接雨水

LeetCode42. 接雨水

单调递减,找到一个大的元素就弹出计算结果。

class Solution {public int trap(int[] height) {Stack<Integer> stack = new Stack<>();int ans = 0;for (int i = 0; i < height.length; i++) {while (!stack.isEmpty() && height[stack.peek()] < height[i]) {Integer pop = stack.pop();if (!stack.isEmpty()) {Integer left = stack.peek();ans += (i - left - 1) * (Math.min(height[left], height[i]) - height[pop]);}}stack.push(i);}return ans;}
}

LeetCode84. 柱状图中最大的矩形(*)

LeetCode84. 柱状图中最大的矩形https://leetcode-cn.com/problems/maximal-rectangle/)

单调递增的栈,4,5,6,(3),当3进行比较的时候,就获取6,以6位底,6和3所在的距离为1,那么面积就是6。以5位底,5和3的距离是2,则结果是10.

class Solution {public int largestRectangleArea(int[] heights) {int[] new_heights = new int[heights.length + 2];for (int i = 1; i < heights.length + 1; i++) {new_heights[i] = heights[i - 1];}//存放的元素到小到大,4,5,6,(3)Stack<Integer> stack = new Stack<>();int ans = 0;for (int i = 0; i < new_heights.length; i++) {if (!stack.isEmpty() && new_heights[stack.peek()] > new_heights[i]) {Integer pop = stack.pop();ans =Math.max((i-1-stack.peek())*new_heights[pop],ans);}stack.push(i);}return ans;}}

优化后的写法

对于index=0前面是没有元素的,所以stack.isEmpty() ? -1 : stack.peek()

对于index==heights.length-1后面是没有元素的,所以要计算前面的元素。

class Solution {public int largestRectangleArea(int[] heights) {Stack<Integer> stack = new Stack<>();int ans = 0;for (int i = 0; i <= heights.length; i++) {while (!stack.isEmpty() && (i == heights.length || heights[stack.peek()] > heights[i])) {Integer pop = stack.pop();Integer left = stack.isEmpty() ? -1 : stack.peek();ans = Math.max((i - 1 - left) * heights[pop], ans);}stack.push(i);}return ans;}
}

LeetCode85. 最大矩形

LeetCode85. 最大矩形

当j=0的时候,height数组记录第0行的数据,进行求最大面积;当j=1的时候,height的数据就是第0行的高度,更新之后就会变成第一行的数据。

求最大面积就是要判断边界。

class Solution {public int maximalRectangle(char[][] matrix) {int maxArea = 0;int[] heights = new int[matrix[0].length];for (int i = 0; i < matrix.length; i++) {for (int j = 0; j < matrix[0].length; j++) {if (matrix[i][j] == '1') {heights[j] += 1;} else {heights[j] = 0;}}maxArea = Math.max(maxArea, getLargestArea(heights));}return maxArea;}private int getLargestArea(int[] heights) {int[] new_heights = new int[heights.length + 2];for (int i = 1; i < heights.length + 1; i++) {new_heights[i] = heights[i - 1];}int ans = 0;// 5,7,6,3Stack<Integer> stack = new Stack<>();for (int i = 0; i < new_heights.length; i++) {while (!stack.isEmpty() && new_heights[i] < new_heights[stack.peek()]) {Integer pop = stack.pop();if (!stack.isEmpty()) {ans = Math.max(ans, (i - stack.peek() - 1) * new_heights[pop]);}}stack.push(i);}return ans;}
}

单调队列

Leetcode239. 滑动窗口最大值

Leetcode239. 滑动窗口最大值

核心思路就是定义双端队列,可以从前面删除元素,也可以从后面删除元素。

当首位元素超过i-k了,不在范围了,进行移除。

当新增元素比末尾元素大的时候,把末尾元素移除,把新增的元素给添加上。

如此,保证队列中存在最多k个元素,且队列前端是最大的元素。其次,第二个元素是除了第一个元素最大的元素。有点像单调栈,比单调栈多了一个移除过期的元素。

class Solution {public int[] maxSlidingWindow(int[] nums, int k) {int[] res = new int[nums.length - k + 1];LinkedList<Integer> queue = new LinkedList<>();for (int i = 0; i < nums.length; i++) {// 0,1,2,3,4,5 当4进来的时候,k=3,小于1的数据就得清空while (!queue.isEmpty() && queue.peek() <= i - k) {queue.poll();}while (!queue.isEmpty() && nums[i] > nums[queue.peekLast()]) {queue.pollLast();}queue.add(i);if (i >= k - 1) {res[i - k + 1] = nums[queue.peek()];}}return res;}
}

在这里插入图片描述

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

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

相关文章

探索 XMLHttpRequest:网页与服务器的异步通信之道(上)

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

多场景建模:阿里多场景多任务元学习方法M2M

multi-scenario multi-task meta learning approach (M2M) 背景 广告领域大部分是针对用户建模的&#xff0c;像点击率预估&#xff0c;很少有针对广告主需求建模&#xff08;广告消耗预估、活跃率/流失率预估、广告曝光量预估&#xff09;&#xff0c;广告的类型较多&#x…

k8s从初识到上天系列第一篇:初识kubernetes

&#x1f609;&#x1f609; 欢迎加入我们的学习交流群呀&#xff01; ✅✅1&#xff1a;这是孙哥suns给大家的福利&#xff01; ✨✨2&#xff1a;我们免费分享Netty、Dubbo、k8s、Mybatis、Spring、SpringSecurity、Docker、Grpc、各种MQ、Rpc、SpringCloud等等很多应用和源码…

CSS之高度塌陷和外边距塌陷

目录 1.高度塌陷&#xff08;原因&#xff0c;如何解决&#xff09; 【概念介绍】 【解决办法】 【概念介绍-BFC】 【拓展-BFC的触发条件】 2.外边距塌陷 &#xff08;原因&#xff0c;如何解决&#xff09; 【概念介绍】 【两种情况】 1.相邻块元素 2.嵌套块元素 【…

5G赋能智慧文旅:科技与文化的完美结合,打造无缝旅游体验,重塑旅游业的未来

一、5G技术&#xff1a;智慧文旅的强大引擎 5G技术的起源可以追溯到2010年&#xff0c;当时世界各国开始意识到4G技术已经达到了瓶颈&#xff0c;无法满足日益增长的移动通信需求。2013年&#xff0c;国际电信联盟&#xff08;ITU&#xff09;成立了5G技术研究组&#xff0c;开…

JSON-handle工具安装及使用

目录 介绍下载安装简单操作 介绍 JSON-Handle 是一款非常好用的用于操作json的浏览器插件&#xff0c;对于开发人员和测试人员来说是一款很好用的工具&#xff0c;如果你还没有用过&#xff0c;请赶紧下载安装吧&#xff0c;下面是安装过程和具体使用。 下载安装 点击下载JSON…

更新至2023年各省环境规制数据合集(七种测算方法)

更新至2023年各省环境规制数据合集&#xff08;七种测算方法&#xff09; 一、2002-2023年全国各省ZF报告词频环境规制关键词词频统计数据 1、时间&#xff1a;2001-2022年 2、指标&#xff1a;文本总长度、仅中英文-文本总长度、文本总词频-全模式、文本总词频-精确模式、环…

【数据结构】 循环队列的基本操作 (C语言版)

目录 一、顺序队列 1、顺序队列的定义&#xff1a; 2、顺序队列的优缺点&#xff1a; 二、循环队列 1、循环队列的定义&#xff1a; 2、循环队列的优缺点&#xff1a; 三、循环队列的基本操作算法&#xff08;C语言&#xff09; 1、宏定义 2、创建结构体 3、循环队…

设计模式——1_6 代理(Proxy)

诗有可解不可解&#xff0c;若镜花水月勿泥其迹可也 —— 谢榛 文章目录 定义图纸一个例子&#xff1a;图片搜索器图片加载搜索器直接在Image添加组合他们 各种各样的代理远程代理&#xff1a;镜中月&#xff0c;水中花保护代理&#xff1a;对象也该有隐私引用代理&#xff1a;…

AR 自回归模型

文章目录 总的代码ADF 检验(是否平稳)差分操作拟合AR 模型预测可视化总的代码 import pandas as pd import numpy as np import matplotlib.pyplot as plt from statsmodels.tsa.ar_model import AutoReg from statsmodels.tsa.stattools import adfuller# 生成一个示例时间序…

【github】使用github action 拉取国外docker镜像

使用github action 拉取国外docker镜像 k8s部署经常用到国外镜像&#xff0c;如果本地无法拉取可以考虑使用github action环境 github action的ci服务器在国外&#xff0c;不受中国防火墙影响github action 自带docker命令运行时直接将你仓库代码拉取下来 步骤 你的国内dock…

仿真机器人-深度学习CV和激光雷达感知(项目2)day03【机器人简介与ROS基础】

文章目录 前言机器人简介机器人应用与前景机器人形态机器人的构成 ROS基础ROS的作用和特点ROS的运行机制ROS常用命令 前言 &#x1f4ab;你好&#xff0c;我是辰chen&#xff0c;本文旨在准备考研复试或就业 &#x1f4ab;本文内容是我为复试准备的第二个项目 &#x1f4ab;欢迎…

手拉手JavaFX UI控件与springboot3+FX桌面开发

目录 javaFx文本 javaFX颜色 字体 Label标签 Button按钮 //按钮单击事件 鼠标、键盘事件 //(鼠标)双击事件 //键盘事件 单选按钮RadioButton 快捷键、键盘事件 CheckBox复选框 ChoiceBox选择框 Text文本 TextField(输入框)、TextArea文本域 //过滤 (传入一个参数&a…

开始学习vue2(Vue方法)

一、过滤器 过滤器&#xff08;Filters&#xff09;是 vue 为开发者提供的功能&#xff0c;常用于文本的格式 化。过滤器可以用在两个地方&#xff1a;插值表达式 和 v-bind 属性绑定。 过滤器应该被添加在 JavaScript 表达式的尾部&#xff0c;由“管道符 ”进行 调用&#…

USB-C接口给显示器带来怎样的变化?

随着科技的不断发展&#xff0c;Type-C接口已经成为现代电子设备中常见的接口标准。它不仅可以提供高速的数据传输&#xff0c;还可以实现快速充电和视频传输等功能。因此&#xff0c;使用Type-C接口的显示器方案也受到了广泛的关注。本文将介绍Type-C接口显示器的优势、应用场…

[MRCTF2020]你传你呢1

尝试了几次&#xff0c;发现是黑名单过滤&#xff0c;只要包含文件后缀有ph就传不了&#xff0c;同时也有类型检测&#xff0c;需要抓包修改content-type 尝试了上传.htaccess&#xff0c;成功了&#xff0c;可以利用这让服务器将jpg文件当作php来解析&#xff0c;详见超详细文…

【K8S 云原生】K8S的图形化工具——Rancher

目录 一、rancher概述 1、rancher概念 2、rancher和K8S的区别&#xff1a; 二、实验 1、安装部署 2、给集群添加监控&#xff1a; 3、创建命名空间&#xff1a; 4、创建deployment&#xff1a; 5、创建service&#xff1a; 6、创建ingress&#xff1a; 7、创建hpa 8…

qt-C++笔记之使用信号和槽实现跨类成员变量同步响应

qt-C笔记之使用信号和槽实现跨类成员变量同步响应 —— 杭州 2024-01-24 code review! 文章目录 qt-C笔记之使用信号和槽实现跨类成员变量同步响应1.运行2.main.cpp3.test.pro4.编译 1.运行 2.main.cpp 代码 #include <QCoreApplication> #include <QObject> #…

leetcode刷题(剑指offer) 105.从前序与中序遍历序列构造二叉树

105.从前序与中序遍历序列构造二叉树 给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的中序遍历&#xff0c;请构造二叉树并返回其根节点。 示例 1: 输入: preorder [3,9,20,15,7], inorder [9,3,15,…

Webpack5 基本使用 - 1

Webpack 是什么 webpack 的核心目的是打包&#xff0c;即把源代码一个一个的 js 文件&#xff0c;打包汇总为一个总文件 bundle.js。 基本配置包括mode指定打包模式&#xff0c;entry指定打包入口&#xff0c;output指定打包输出目录。 另外&#xff0c;由于 webpack默认只能打…