Leetcode栈&队列
Leetcode栈&队列
232.用栈实现队列
题干:
思路:
- 栈是
FILO
,队列是FIFO
,所以如果要用栈实现队列,目的就是要栈实现一个FIFO
的特性。 - 具体实现方法可以理解为,准备两个栈,一个栈用作输入栈,入数据就存数据,一个栈用作输出栈,出数据就入数据再弹数据。
代码:
class MyQueue {
/**
* 先声明变量,留在MyQueue方法中进行Init
*/
Stack<Integer> stackIn;
Stack<Integer> stackOut;
public MyQueue() {
stackIn=new Stack<Integer>();
stackOut=new Stack<Integer>();
}
public void push(int x) {
stackIn.push(x);
}
public int pop() {
dumpStackIn();
return stackOut.pop();
}
public int peek() {
dumpStackIn();
return stackOut.peek();
}
public boolean empty() {
//不难得出,当输入输出栈均为空时,队列就是空的
return stackOut.isEmpty()&&stackIn.isEmpty();
}
private void dumpStackIn(){
if(!stackOut.isEmpty()){
return;
}
while (!stackIn.isEmpty()){
stackOut.push(stackIn.pop());
}
}
}
20.有效的括号
题干:
思路:
- 这种匹配类的题目都可以用栈来解决。当某组括号的左括号被扫描到时,我们就将与它配对的括号入栈(它本身也可以,但是存入配对的括号在后续步骤中可以通过判断是否相同来加快速度),之后遇到相同的括号就将其出栈。
- 第一种情况:扫描完毕,栈同时也是空的。对应着有效的字符串
- 第二种情况:扫描未完毕,栈已经空了。对应着左括号数量少于右括号,不符合要求
- 第三种情况:扫描完毕,栈未空,说明左括号数量大于右括号,不符合要求
- 第四种情况:扫描未完毕,发现栈顶元素与当前括号类型不匹配,不符合要求
代码:
class Solution {
public boolean isValid(String s) {
//这里使用双向链表deque来模拟栈
Deque<Character> deque = new LinkedList<>();
char ch;
for (int i = 0; i < s.length(); i++) {
ch = s.charAt(i);
if (ch == '(') {
deque.push(')');
}else if (ch == '{') {
deque.push('}');
}else if (ch == '[') {
deque.push(']');
} else if (deque.isEmpty() || deque.peek() != ch) {
return false;
}else {
deque.pop();
}
}
return deque.isEmpty();
}
}
1047.删除字符串中的所有相邻重复项
题干:
思路:
- 与
有效的括号
有着异曲同工之妙,我们依次扫描传入的字符串,并判断栈顶元素是否与当前扫描到的字符相同,如果相同,则出栈此元素,扫描完毕后,将栈中元素弹出逆序即可。 - 在这题中,我们将频繁使用到
删除
这个操作,根据数据结构的知识,这种情况下采用Array结构将比LinkedList结构快一些
代码:
class Solution {
public String removeDuplicates(String s) {
Deque<Character> deque=new LinkedList<>();
char letter;
for(int i=0;i<s.length();i++){
letter=s.charAt(i);
if(deque.isEmpty()||deque.peek()!=letter){
deque.push(letter);
}else{
deque.pop();
}
}
String ans="";
while (!deque.isEmpty()){
//每次将上一次的ans放到末尾,就可以起到reverse的作用了
ans=deque.pop()+ans;
}
return ans;
}
}
Tips:
- 写的时候将
deque.pop()
写成了deque.add()
,查询代码以后发现了两者的区别 - 首先是返回值不同,push的返回值为void,add的返回值为Boolean;其次是位置不同,push插入头,add插入尾
150.逆波兰表达式求值
题干:
Tips:
- 表达式有前缀、中缀、后缀,其中前缀表达式称为波兰表达式,这也就是为什么后缀表达式叫逆波兰表达式,中缀表达式就是人们日常运算时所书写的形式,例如
1+1+1+1=4
这种。分类标准就是依据将运算符号放置在运算数前、中还是后。
思路:
- 读《算法》第四版的时候,书中的经典例题,没遇到运算符之前就入栈,遇到运算符就将运算符出栈,并同时出栈两个数字,进行与对应的出栈的运算符的运算操作,并最后将运算结果压入栈中。
- 需要注意的是,在进行减法与除法这类需要考虑顺序的运算时,不要直接就大意的认为将出栈的两个数字相减或是相除就行了。
代码:
class Solution {
public int evalRPN(String[] tokens) {
Deque<Integer> stack=new LinkedList<Integer>();
for(int i=0;i<tokens.length;i++){
if("+".equals(tokens[i])){
stack.push(stack.pop()+stack.pop());
}else if("-".equals(tokens[i])){
stack.push(-stack.pop()+stack.pop());
}else if("*".equals(tokens[i])){
stack.push(stack.pop()*stack.pop());
}else if("/".equals(tokens[i])){
int temp1=stack.pop();
int temp2=stack.pop();
stack.push(temp2/temp1);
}else{
stack.push(Integer.valueOf(tokens[i]));
}
}
return stack.pop();
}
}
347.前K个高频元素
题干:
思路:
- 第一个想法是利用哈希表存入数字与其出现的次数,排序之后取最前的K个value对应的key就可以了。
代码:
class Solution {
public int[] topKFrequent(int[] nums, int k) {
int[] ans=new int[k];
Map<Integer,Integer> map=new HashMap();
for(int i:nums){
if(map.containsKey(i)){
map.put(i,map.get(i)+1);
}else {
map.put(i,1);
}
}
int max=0;
for(Map.Entry<Integer,Integer> entry:map.entrySet()){
if(entry.getValue()>max){
max=entry.getValue();
}
}
while (k>0){
for(Map.Entry<Integer,Integer> entry:map.entrySet()){
if(entry.getValue()==max){
ans[k-1]=entry.getKey();
k--;
}
}
max--;
}
return ans;
}
}
Tips:
在Hashmap中,每一个Key-Value被看作是一个set集合。
为了更便捷的获取Key-Value,使用Entry来进行编写,for-each循环中用entrySet把每一个键值对取出进行遍历。
Leetcode栈&队列的更多相关文章
- 栈&队列&并查集&哈希表(julyedu网课整理)
date: 2018-11-25 08:31:30 updated: 2018-11-25 08:31:30 栈&队列&并查集&哈希表(julyedu网课整理) 栈和队列 1. ...
- java 集合 Connection 栈 队列 及一些常用
集合家族图 ---|Collection: 单列集合 ---|List: 有存储顺序 , 可重复 ---|ArrayList: 数组实现 , 查找快 , 增删慢 ---|LinkedList: 链表实 ...
- Java 容器之 Connection栈队列及一些常用
集合家族图 ---|Collection: 单列集合 ---|List: 有存储顺序 , 可重复 ---|ArrayList: 数组实现 , 查找快 , 增删慢 ---|LinkedList: 链表实 ...
- java面向对象的栈 队列 优先级队列的比较
栈 队列 有序队列数据结构的生命周期比那些数据库类型的结构(比如链表,树)要短得多.在程序操作执行期间他们才被创建,通常用他们去执行某项特殊的任务:当完成任务之后,他们就会被销毁.这三个数据结构还有一 ...
- C++实现一个简单的双栈队列
双栈队列的原理是用两个栈结构模拟一个队列, 一个栈A模拟队尾, 入队的元素全部压入此栈, 另一个栈B模拟队首, 出队时将栈A的元素弹入栈B, 将栈B的栈顶元素弹出 此结构类似汉诺塔, 非常经典, 这里 ...
- leetcode 栈和队列类型题
1,Valid Parentheses bool isVaild1(string& s) { // 直接列举,不易扩展 stack<char> stk; ; i < s.le ...
- leetcode 栈 括号匹配
https://oj.leetcode.com/problems/valid-parentheses/ 遇到左括号入栈,遇到右括号出栈找匹配,为空或不匹配为空, public class Soluti ...
- 【图解数据结构】 栈&队列
[TOC] 勤于总结,持续输出! 1.栈 1.1栈的定义 栈(stack)是限定在表尾进行插入和删除的操作的线性表. 我们把允许插入和删除的一端称为栈顶(top),另一端称为栈底(bottom),不包 ...
- 数据结构 栈&队列
2-4 依次在初始为空的队列中插入元素a,b,c,d以后,紧接着做了两次删除操作,此时的队头元素是( ) 删除,移动头指针: 增加,移动尾指针: 删除a,b ,队头c 2-3 在一个链队列中,fron ...
随机推荐
- c++头文件的一个误导
通常情况下,我们都认为c++的头文件是这样的: #include <bits/stdc++.h> using namespace std; int main() 但c++也可以用c的头文件 ...
- DQL排序查询和DQL聚合函数
DQL:查询语句 排序查询 语法: order by 字句 order by 排序字段1 排序方式1,排序字段2 排序方式2... 排序方式: ASC:升序,默认的 DESC:降序 SELECT * ...
- mysql Insert强化
INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO] tbl_name [(col_name,...)] VALUES ({e ...
- SDK和API的直接区别
狭义的说法,在实际工作中, 如果对方需要你提供一个api,是指一个工程提供给另外一个工程的接口(一般是基于http协议). 如果对方需要你提供一个sdk,是指基于对方工程的编程语言,提供一个代码包.在 ...
- 一文搞懂什么是kubernetes Service
1.什么是Service? 在kubernets中,Pod是应用程序的载体,Pod你可以想象成就是容器,为动态的一组Pod提供一个固定的访问入口,它是以一种叫ClusterIP地址来进行标识,而Clu ...
- MySQL主从复制之GTID模式介绍
GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. GTID概述 MySQL5.6 在原有主从复制的基础上增加了一个新的复制方式,即基于GTID的复制方式,它由UUID和事务 ...
- 巨细靡遗流程控制,Go lang1.18入门精炼教程,由白丁入鸿儒,Go lang流程结构详解EP09
流程结构就是指程序逻辑到底怎么执行,进而言之,程序执行逻辑的顺序.众所周知,程序整体都是自上由下执行的,但有的时候,又不仅仅是从上往下执行那么简单,大体上,Go lang程序的流程控制结构一共有三种: ...
- Git 02 安装
参考源 https://www.bilibili.com/video/BV1FE411P7B3?spm_id_from=333.999.0.0 版本 本文章基于 Git 2.35.1.2 这里以安装 ...
- SpingBoot解析Excel数据
前言 在最近的工作中,由于导入模板除了前三列(姓名.手机号.实发工资)固定:其余的列不固定,并且可以做到两个模板的数据都能够正常入库进行对应业务处理. 一.数据模板数据展示: (1)模板一 (2)模板 ...
- 检查一个数值是否为有限的Number.isFinite()
如果参数类型不是数值,Number.isFinite()一律返回false. Number.isFinite(15); // true Number.isFinite(0.8); // true Nu ...