LeetCode——栈和队列(Java)

栈和队列

  • 简介
  • [简单] 232. 用栈实现队列
  • [简单] 225. 用队列实现栈
  • [简单] 20. 有效的括号
  • [简单] 1047. 删除字符串中的所有相邻重复项
  • [中等] 150. 逆波兰表达式求值
  • [困难] 239. 滑动窗口最大值
  • [中等] 347. 前 K 个高频元素

简介

记录一下自己刷题的历程以及代码。写题过程中参考了 代码随想录。会附上一些个人的思路,如果有错误,可以在评论区提醒一下。

涉及到:栈、队列、双端队列、map、优先队列、java装箱拆箱问题。

[简单] 232. 用栈实现队列

原题链接

使用两个栈实现,stack1接受数据,每次要pop或者peek的时候,把stack1里的数据再出栈入栈 放置到stack2中,这样又对stack1中的数据做了一次转置。注意stack2中有元素时,stack1不能向stack2传入数据,否则会出现顺序错乱。

class MyQueue {//假设了所有操作都是有效的public Stack<Integer> stack1;public Stack<Integer> stack2;public MyQueue() {stack1 = new Stack<>();stack2 = new Stack<>();}public void push(int x) {stack1.push(x);}public int pop() {reverse();return stack2.pop();}public int peek() {reverse();return stack2.peek();}public boolean empty() {if(stack2.empty() && stack1.empty()){return true;}return false;}//stack2中没有元素时,把stack1中元素全部转置private void reverse(){if(stack2.empty()) {while (!stack1.empty()) {Integer temp = stack1.pop();stack2.push(temp);}}}
}

[简单] 225. 用队列实现栈

原题链接

使用两个队列实现,时刻保持只有一个队列A存放元素,另一个队列B用于pop或者top操作时接收A的数据,就可以对队列A队尾的元素进行操作。队列A和队列B是相对概念,两个队列某一时刻都可能是存放元素的那个队列。

class MyStack {Queue<Integer> queue1;Queue<Integer> queue2;public MyStack() {queue1 = new LinkedList<Integer>();queue2 = new LinkedList<Integer>();}public void push(int x) {if(queue1.isEmpty()) queue2.add(x);else queue1.add(x);}public int pop() {if(queue1.isEmpty()) {while(queue2.size() > 1){queue1.add(queue2.poll());}return queue2.poll();}while(queue1.size() > 1){queue2.add(queue1.poll());}return queue1.poll();}public int top() {if(queue1.isEmpty()) {while(queue2.size() > 1){queue1.add(queue2.poll());}Integer temp =  queue2.peek();queue1.add(queue2.poll());return temp;}while(queue1.size() > 1){queue2.add(queue1.poll());}Integer temp =  queue1.peek();queue2.add(queue1.poll());return temp;}public boolean empty() {if(queue1.isEmpty() && queue2.isEmpty()){return true;}return false;}
}

[简单] 20. 有效的括号

原题链接

使用栈做符号匹配,碰到左括号压栈,碰到右括号,看目前栈顶是否与之匹配,若不匹配或空,则表示匹配错误。若循环结束栈不为空,表示有多余的左括号。

class Solution {public boolean isValid(String s) {Stack<Character> stack = new Stack<>();for(int i = 0; i < s.length(); i++){if(s.charAt(i) == '[' || s.charAt(i) == '{' || s.charAt(i) == '('){stack.push(s.charAt(i));}else if(s.charAt(i) == ']'){if(stack.empty() || stack.peek() != '[') return false;stack.pop();}else if(s.charAt(i) == '}'){if(stack.empty() || stack.peek() != '{') return false;stack.pop();}else if(s.charAt(i) == ')'){if(stack.empty() || stack.peek() != '(') return false;stack.pop();}}if(stack.empty()) return true;return false;}
}

[简单] 1047. 删除字符串中的所有相邻重复项

原题链接

方法①:使用队列,每次入栈时如果与栈顶元素相同,则不入栈,并弹出栈顶元素。

class Solution {public String removeDuplicates(String s) {ArrayDeque<Character> stack = new ArrayDeque<>();for(int i = 0; i < s.length(); i++){if(!stack.isEmpty() && stack.peek() == s.charAt(i)){stack.pop();}else{stack.push(s.charAt(i));}}String str = "";//剩余的元素即为不重复的元素while (!stack.isEmpty()) {str = stack.pop() + str;}return str;}
}

方法②:快慢指针法指针法,就把[0-slow]范围内看作一个栈,栈顶是slow指针的位置,一旦出现c[slow] == c[slow - 1],就回退一次,将栈顶弹出,否则就将当前fast遍历到的元素加进来。

class Solution {//快慢指针法public String removeDuplicates(String s) {//声明字符串数组用于修改,String类是静态变量char[] c = s.toCharArray();int slow = 0;int fast = 0;while(fast < c.length){c[slow] = c[fast];if(slow > 0 && c[slow] == c[slow - 1]) {slow--;} else {slow++;}fast++;}return new String(c, 0, slow);}
}

[中等] 150. 逆波兰表达式求值

原题链接

token是数字,就做类型转换压入栈,如果是运算符,弹出栈顶两个数字做运算,记住减法和除法是有顺序的。

class Solution {public int evalRPN(String[] tokens) {ArrayDeque<Integer> stack = new ArrayDeque<>();for(int i = 0; i < tokens.length; i++){if(tokens[i].equals("+")){int temp1 = stack.pop();int temp2 = stack.pop();stack.push(temp1 + temp2);}else if(tokens[i].equals("-")){int temp1 = stack.pop();int temp2 = stack.pop();stack.push(temp2 - temp1);}else if(tokens[i].equals("*")){int temp1 = stack.pop();int temp2 = stack.pop();stack.push(temp1 * temp2);}else if(tokens[i].equals("/")){int temp1 = stack.pop();int temp2 = stack.pop();stack.push(temp2 / temp1);}else{stack.push(Integer.parseInt(tokens[i]));}}return stack.pop();}
}

[困难] 239. 滑动窗口最大值

原题链接

原先pop方法和push方法都是Integer参数,一半示例无法通过,改成int之后顺利通过。

涉及到装箱拆箱问题,==运算符可以应用与对象包装器对象,只不过检测的事对象是否指向同一个存储区域。比如Integer a = 1000;Integer b =1000a==b 未必是true。

缓存机制:Java 基本数据类型的包装类型的大部分都用到了缓存机制来提升性能。Byte,Short,Integer,Long 这 4 种包装类默认创建了数值 [-128,127] 的相应类型的缓存数据
在这里插入图片描述

class MoQueue{public ArrayDeque<Integer> queue;public MoQueue(){queue = new ArrayDeque<Integer>();}public void pop(int a){if(!queue.isEmpty() && queue.peek() == a)queue.pollFirst();return;}public void push(int a){while(!queue.isEmpty() && a > queue.getLast()){queue.pollLast();}queue.addLast(a);}public Integer peek(){return queue.peek();}
}
class Solution {public int[] maxSlidingWindow(int[] nums, int k) {MoQueue moQueue = new MoQueue();int[] answer = new int[nums.length - k + 1];for(int i = 0; i < k; i++){moQueue .push(nums[i]);}//放入第一个窗口最大值answer[0] = moQueue.peek();for(int i = k; i < nums.length; i++){moQueue.pop(nums[i - k]);moQueue.push(nums[i]);answer[i - k + 1] = moQueue.peek();}return answer;}
}

[中等] 347. 前 K 个高频元素

原题链接

使用map存储键值对记录每个数字出现的频次,再使用优先队列定义排序,获取前k个队头元素即可。

class Solution {public int[] topKFrequent(int[] nums, int k) {Map<Integer,Integer> map = new HashMap<>();//key为数组元素值,val为对应出现次数for(int num:nums){map.put(num,map.getOrDefault(num,0)+1);}PriorityQueue<Integer> pq = new PriorityQueue<>(new Comparator<Integer>() {@Overridepublic int compare(Integer a, Integer b) {return map.get(b) - map.get(a);}});int[] ans = new int[k];int i = 0;for(Integer key : map.keySet()){pq.add(key);}while(i < k){ans[i++] = pq.remove();}return ans;}
}

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

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

相关文章

网工内推 | 项目经理,软考证书优先,最高26K,加班补贴

01 龙盈智达 招聘岗位&#xff1a;项目经理 职责描述&#xff1a; 1 根据业务员需求&#xff0c;完成生态圈下账簿中心系统的开发管理工作。 2 负责账簿中心实施过程中的需求调研分析、方案设计、开发测试、系统上线等工作的计划、组织协调、沟通等方面管理工作。 3 完成系统核…

Spring八股 常见面试题

什么是Spring Bean 简单来说&#xff0c;Bean 代指的就是那些被 IoC 容器所管理的对象。我们需要告诉 IoC 容器帮助我们管理哪些对象&#xff0c;这个是通过配置元数据来定义的。配置元数据可以是 XML 文件、注解或者 Java 配置类。 将一个类声明为 Bean 的注解有哪些? Com…

发掘效率黑科技:Allure报告助您事半功倍提升测试效能!

Allure 简介与安装 Allure 是由 Java 语⾔开发的⼀个轻量级&#xff0c;灵活的测试报告⼯具。 Allure 多平台的 Report 框架。 Allure ⽀持多语⾔&#xff0c;包括 python、JaveScript、PHP、Ruby 等。 可以为开发/测试/管理等人员提供详尽的的测试报告&#xff0c;包括测试…

el-table 指定表格合并行与单元格,以及表头合并单元格

1&#xff1a;页面html <template><div class"container"><div class"flex-end"><el-button type"primary" click"allEndBtn">批量办结</el-button><el-button type"primary" click"…

面向对象编程入门:掌握C++类的基础(2/3):深入理解C++中的类成员函数

在C编程中&#xff0c;类是构建程序的基石&#xff0c;而理解类的默认成员函数对于高效使用C至关重要。本文将深入探讨这六个默认成员函数及其他相关概念&#xff0c;提供给读者一个全面的视角。 类的6个默认成员函数&#xff1a; 如果一个类中什么成员都没有&#xff0c;简称为…

【前端素材】推荐优质后台管理系统Dashy平台模板(附源码)

一、需求分析 后台管理系统&#xff08;或称作管理后台、管理系统、后台管理平台&#xff09;是一种专门用于管理网站、应用程序或系统后台运营的软件系统。它通常由一系列功能模块组成&#xff0c;为管理员提供了管理、监控和控制网站或应用程序的各个方面的工具和界面。以下…

MySQL 如何从 Binlog 找出变更记录并回滚

文章目录 前言1. 案例模拟1.1 确认信息1.2 下载 Binlog1.3 准备环境1.4 注册 Binlog1.5 准备结构信息1.6 Python 订阅1.7 输出结果展示 2. 原理解析2.1 程序设计2.2 模块版本 总结 前言 最近有研发同学问我&#xff1a;有一个问题&#xff0c;想查一个 ID 为 xxxx 的 sku 什么…

经典DP-最长单调子序列

最长递增子序列 思路 定义状态&#xff1a; 我们定义一个数组 dp&#xff0c;其中 dp[i] 表示以 nums[i] 结尾的最长递增子序列的长度。初始化状态&#xff1a; 对于数组中的每个元素 nums[i]&#xff0c;初始时都可以被视为一个长度为1的递增子序列&#xff0c;因此 dp[i] 的…

常用的桌面端自动化测试工具

桌面端软件相比Web端软件而言&#xff0c;因为界面元素的多种形态&#xff0c;导致其定位更难&#xff0c;目前市面上常见的定位方式一般是两种&#xff0c;一种是通过控件本身的属性定位&#xff0c;第二种是通过图片识别来定位&#xff0c;市面上常用的可以支持不同操作系统的…

Qt6内嵌CEF

一、下载CEF CEF下载地址&#xff1a;https://cef-builds.spotifycdn.com/index.html 或https://bitbucket.org/chromiumembedded/cef/src/master/ 选择对应系统的版本&#xff08;本教程选择的是116.0.19&#xff09; CMake下载地址&#xff1a;https://cmake.org/download…

thefour--Love is like a tide

最后一部分了&#xff0c;要开始进行我们的训练了。 先上代码&#xff1a; import os import numpy as np from tqdm import tqdm import tensorflow as tf from thetwo import NeuralStyleTransferModel import theone import thethree #创建模型 modelNeuralStyleTransferM…

代码随想录训练营第31天 | 理论基础、LeetCode 455.分发饼干、

目录 理论基础 视频讲解&#xff1a;手把手带你学会操作链表 | 贪心算法理论基础&#xff01;_哔哩哔哩_bilibili LeetCode 455.分发饼干 文章讲解&#xff1a;代码随想录(programmercarl.com) 视频讲解&#xff1a;贪心算法&#xff0c;你想先喂哪个小孩&#xff1f;| Le…

【GameFramework框架内置模块】7、事件(Event)

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 【GameFramework框架】系列教程目录&#xff1a; https://blog.csdn.net/q7…

【Vue】路由

&#x1f4dd;个人主页&#xff1a;五敷有你 &#x1f525;系列专栏&#xff1a;Vue ⛺️稳中求进&#xff0c;晒太阳 目录 路由 单页应用程序 总结&#xff1a; VueRouter 核心步骤&#xff1a; 组件存放目录的问题 路由的封装 声明式导航 声明式导航 - 导航链…

Go语言必知必会100问题-11 使用选项模式

使用选项模式 在设计API时&#xff0c;可能会遇到一个问题&#xff1a;如何处理可选配置&#xff1f;有效的解决可选配置问题可以提高API的灵活性。本文通过一个具体示例说明处理可选配置的一些方法。该示例的要求是设计一个对外提供创建HTTP服务器的库函数。函数定义如下&…

服了,阿里云服务器和腾讯云服务器价格差不多怎么选择?

2024年阿里云服务器和腾讯云服务器价格战已经打响&#xff0c;阿里云服务器优惠61元一年起&#xff0c;腾讯云服务器62元一年&#xff0c;2核2G3M、2核4G、4核8G、8核16G、16核32G、16核64G等配置价格对比&#xff0c;阿腾云atengyun.com整理阿里云和腾讯云服务器详细配置价格表…

高级语言期末2011级B卷(计算机学院)

1.编写函数&#xff0c;实现按照如下公式计算的功能&#xff0c;其中n为自然数 #include <stdio.h>int fac(int n) {if(n0)return 1;elsereturn n*fac(n-1); }float fun(int n) {float flag;float sum0;for(int i0; i<n; i) {flagi/((i1)*fac(i2));sumflag;}return su…

重推请求之curl和fiddler

在实际的项目中会有出现问题&#xff0c;想重现的场景&#xff0c;比较重新调用一个服务&#xff0c;那么如何进行快速的重推请求呢&#xff0c;记录下来&#xff0c;方便备查。 主要有curl和fiddler两种方式&#xff0c;下面详细说。 方式一、curl 命令 curl 是一个利用URL规…

云上攻防-云服务篇弹性计算服务器云数据库实例元数据控制角色AK控制台接管

知识点: 1、云服务-弹性计算服务器-元数据&SSRF&AK 2、云服务-云数据库-外部连接&权限提升 章节点&#xff1a; 云场景攻防&#xff1a;公有云&#xff0c;私有云&#xff0c;混合云&#xff0c;虚拟化集群&#xff0c;云桌面等 云厂商攻防&#xff1a;阿里云&am…

租赁小程序|租赁系统|租赁软件开发带来高效运营

随着社会的不断发展和科技的不断进步&#xff0c;越来越多的企业开始关注设备租赁业务。设备租赁作为一种短期使用设备的方式&#xff0c;为企业提供了灵活和成本节约的优势。针对设备租赁业务的管理和提升企业竞争力的需求&#xff0c;很多企业选择定制开发设备租赁系统。本文…