IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 【Java数据结构】栈和队列(概念+练题) -> 正文阅读

[数据结构与算法]【Java数据结构】栈和队列(概念+练题)

目录

1. 实现栈(数组)

MyStack.java

2. 实现队列(链式)

MyQueueLinked.java

3. 实现循环队列

MyCircularQueue.java

4. LeetCode习题

4.1 括号匹配问题

4.2 用队列实现栈

4.3?用栈实现队列

4.4 实现一个最小栈


  • 栈:先进后出
  • 队列:先进先出

1. 实现栈(数组)

MyStack.java

public class MyStack {
    public int[] elem;
    public int usedSize;

    public MyStack() {
        this.elem = new int[10];
    }

    //判断是否栈满
    public boolean isFull() {
        if (this.usedSize == this.elem.length) {
            return true;
        }
        return false;
    }
    //push
    public void push(int item) {
        if(isFull()) {
            //扩容
            this.elem = Arrays.copyOf(this.elem,2*2*this.elem.length);
        }
        this.elem[this.usedSize] = item;
        this.usedSize++;
    }

    //pop
    public int pop() {
        if(empty()) {
            throw new RuntimeException("栈空了!");
        }
        int val = this.elem[this.usedSize-1];
        this.usedSize--;
        return val;
    }

    //peek
    public int peek() {
        if(empty()) {
            throw new RuntimeException("栈空了!");
        }
        return this.elem[this.usedSize-1];
    }

    //判断为空
    public boolean empty() {
        if(this.usedSize == 0) return true;
        return false;
    }
}

2. 实现队列(链式)

MyQueueLinked.java

class Node {
    public int data;
    public Node next;

    public Node(int data) {
        this.data = data;
    }
}
public class MyQueueLinked {
    private Node front;
    private Node rear;
    private int usedSize = 0;

    //入队列
    public void offer(int val) {
        Node node = new Node(val);
        if (this.front == null) {
            this.front = node;
            this.rear = node;
        } else {
            this.rear.next = node;
            this.rear = node;
        }
        this.usedSize++;
    }
    //出队头元素
    public int poll() {
        if(isEmpty()) {
            throw new RuntimeException("队列为空!");
        }
        int val = this.front.data;
        if(this.front.next == null) {
            //只有一个结点
            this.front = null;
            this.rear = null;
        } else {
            this.front = this.front.next;
        }
        this.usedSize--;
        return val;
    }

    //得到队头元素
    public int peek() {
        if(isEmpty()) {
            throw new RuntimeException("队列为空!");
        }
        return this.front.data;
    }
    public boolean isEmpty() {
        return this.usedSize == 0;
    }
    public int size() {
        return this.usedSize;
    }
}

3. 实现循环队列

MyCircularQueue.java

public class MyCircularQueue {
    private int[] elem;
    private int usedSize;
    private int front;
    private int rear;

    public MyCircularQueue(int k) {
        this.elem = new int[k+1];
    }
    //入队
    public boolean enQueue(int value) {
        if (isFull()) {
            return false;
        }
        this.elem[this.rear] = value;
        this.rear = (this.rear+1) % this.elem.length;
        return true;
    }

    //出队
    public boolean deQueue() {
        if (isEmpty()) {
            return false;
        }
        this.front = (this.front+1) % this.elem.length;
        return true;
    }

    //得到对头元素
    public int Front() {
        if ((isEmpty())) {
            return -1;
        }
        return this.elem[this.front];
    }

    public int Rear() {
        if (isEmpty()) {
            return -1;
        }
        if (this.rear == 0) {
            return this.elem[this.elem.length-1];
        }
        return this.elem[this.rear-1];
    }

    public boolean isEmpty() {
        if (this.front == this.rear) {
            return true;
        }
        return false;
    }

    public boolean isFull() {
        if((this.rear+1) % this.elem.length == this.front) {
            return true;
        }
        return false;
    }
}

4. LeetCode习题

4.1 括号匹配问题

20. 有效的括号 - 力扣(LeetCode) (leetcode-cn.com)

思路:先判断是否为空、s.length()是否为0或奇数。

然后变量字符串,如果为左括号,则push进栈,如果为右括号,则与pop栈中的对比。

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

4.2 用队列实现栈

225. 用队列实现栈 - 力扣(LeetCode) (leetcode-cn.com)

class MyStack {

    private Queue<Integer> qu1 = new LinkedList<>();
    private Queue<Integer> qu2 = new LinkedList<>();
    public MyStack() {
        
    }
    
    //入栈
    public void push(int x) {
        if(!qu1.isEmpty()) {
            qu1.offer(x);
        } else if (!qu2.isEmpty()){
            qu2.offer(x);
        } else {
            qu1.offer(x);
        }
    }
    //出栈
    public int pop() {
        if(empty()) return -1;
        int e = -1;
        if (!qu1.isEmpty()) {
            int size = qu1.size();
            for (int i = 0; i < size -1; i++) {
                e = qu1.poll();
                qu2.offer(e);
            }
            e = qu1.poll();
        } else {
            int size = qu2.size();
            for (int i = 0; i < size -1; i++) {
                e = qu2.poll();
                qu1.offer(e);
            }
            e = qu2.poll();
        }
        return e;
    }
    //得到栈顶元素,不删除
    public int top() {
        if(empty()) return -1;
        int e = -1;
        if (!qu1.isEmpty()) {
            int size = qu1.size();
            for (int i = 0; i < size; i++) {
                e = qu1.poll();
                qu2.offer(e);
            }
        } else {
            int size = qu2.size();
            for (int i = 0; i < size; i++) {
                e = qu2.poll();
                qu1.offer(e);
            }
        }
        return e;
    }
    //是否为空
    public boolean empty() {
        return qu1.isEmpty() && qu2.isEmpty();
    }
}

4.3?用栈实现队列

232. 用栈实现队列 - 力扣(LeetCode) (leetcode-cn.com)

一个栈用来入,另一个栈用来出

class MyQueue {
    private Stack<Integer> s1 = new Stack<>();
    private Stack<Integer> s2 = new Stack<>();

    public MyQueue() {

    }
    
    public void push(int x) {
        s1.push(x);   //指定push到第一个栈
    }
    
    public int pop() {
        if (empty()) return -1;
        if (s2.empty()) {
            while (!s1.empty()) {
                s2.push(s1.pop());
           }
        }
        return s2.pop();
    }
    
    public int peek() {
        if (empty()) return -1;
        if (s2.empty()) {
            while (!s1.empty()) {
                s2.push(s1.pop());
           }
        }
        return s2.peek();
    }
    
    public boolean empty() {
        return s1.empty() && s2.empty();
    }
}

4.4 实现一个最小栈

155. 最小栈 - 力扣(LeetCode) (leetcode-cn.com)

两个栈,一个正常栈,另一个栈存储最小值

class MinStack {
    private Stack<Integer> s1 = new Stack<>();
    private Stack<Integer> s2 = new Stack<>();
    public MinStack() {

    }
    
    public void push(int val) {
        s1.push(val);
        if (s2.empty() || val <= s2.peek()) {
            s2.push(val);
        }
    }
    
    public void pop() {
        int val = s1.pop();
        if(!s2.empty() && s2.peek()==val) {
            s2.pop();
        }
    }
    
    public int top() {
        if(!s1.empty()) {
            return s1.peek();
        }
        return 0;
    }
    
    public int getMin() {
        if(!s2.empty()) {
            return s2.peek();
        }
        return 0;
    }
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-03-24 00:48:42  更:2022-03-24 00:49:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:13:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码