栈和队列(内附模拟实现代码)

news2024/9/24 23:21:49

一,栈

1.1 栈的概念

栈是一种线性表(是一种特殊的线性表),栈只允许在固定一端进行插入和删除元素。插入元素的一端称为栈顶,另一端称为栈底。所以栈中的数据元素满足先进后出(First In Last Out)的原则。

1.2 栈的操作

压栈(push):栈中插入操作叫做压栈/入栈,在栈顶插入元素

出栈(pop):栈中删除操作叫做出栈,在栈顶删除元素

读取栈顶元素(peek):读取栈顶的元素,但是不弹出该元素

获取栈中元素个数(size):获取栈的元素个数

判断栈为空(empty):判断栈是否为空,返回true/false

1.3 栈的模拟实现

假设栈的底层实现逻辑是一个顺序表

代码如下:

import java.util.Arrays;

public class MyStack {

    public int[] elem;//定义一个数组用来存储栈内的元素
    public int usedSize;//用来记录栈内的元素个数
    public static final int DEFAULT_SIZE = 10;

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

    //push操作
    public void push(int val) {
        //需要判断栈是否满了
        if (isFull()) {
            this.elem = Arrays.copyOf(this.elem, 2 * this.elem.length);
        }
        this.elem[this.usedSize] = val;
        this.usedSize++;
    }

    private boolean isFull() {
        return this.usedSize == this.elem.length;
    }

    //pop操作
    public int pop() {
        //判断栈是否为空
        if (empty()) {
            return -1;//假设栈为空返回-1,也可以抛异常
        }
        int ret = this.elem[this.usedSize - 1];
        this.usedSize--;
        return ret;
    }

    //empty操作
    public boolean empty() {
        return this.usedSize == 0;
    }

    //peek操作
    public int peek() {
        //判断栈是否为空
        if (empty()) {
            return -1;//假设栈为空返回-1,也可以抛异常
        }
        return this.elem[this.usedSize - 1];
    }

    //size操作
    public int size() {
        return this.usedSize;
    }
}

1.4 栈的应用场景

    • 判断出入栈序列是否匹配

示例:若进栈序列为 1,2,3,4 ,进栈过程中可以出栈,则下列不可能的一个出栈序列是(C

A: 1,4,3,2 B: 2,3,4,1 C: 3,1,4,2 D: 3,4,2,1

注意做这种题时只需要对每一种出入栈序列进行手动模拟一遍即可!

    • 将递归转化为循环

递归的优点:递归的代码简洁

循环的优点:代码的效率更高

示例:逆序打印链表

import java.util.Stack;

public class displayList {
    //递归的方式逆序打印链表
    public void display1() {
        if(head != null){
            printList(head.next);//递归函数
            System.out.print(head.val + " ");
        }
    }

    public void printList(ListNode cur){
        if(cur == null){
            return;
        }

    //循环的方式逆序打印链表
    public void display2() {
        //创建一个栈按照链表的顺序从头到尾将每一个节点压入栈中
            Stack<ListNode> stack = new Stack<ListNode>();
            ListNode cur = head;
            //入栈
            while(cur != null) {
                stack.push(cur);
                cur = cur.next;
            }
           //出栈
        while(!stack.empty()) {
            System.out.print(cur.val + " ");
        }
            System.out.println();
    }
}

3. 括号匹配

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

4. 逆波兰表达式求值

150. 逆波兰表达式求值 - 力扣(LeetCode)

5. 出栈入栈次序匹配

栈的压入、弹出序列_牛客题霸_牛客网 (nowcoder.com)

这里的3 4 5后续都将以OJ的形式进行讲解!!!

二,队列

2.1 队列的概念

队列也是一种线性表(也是一种特殊的线性表),只允许在一端进行插入数据,在另一端进行删除操作。插入元素的一端叫队尾,删除元素的一端叫队头。所以队列中的数据元素满足先进先出(First In First Out)的原则。

2.2 队列的操作

入队(offer):队中插入元素的操作叫入队,在队尾进行插入

出队(poll):队中删除元素的操作叫出队,在队头进行删除

读取队头元素(peek):读取队头的元素,但是不弹出该元素

读取队中的元素个数(size):获取栈的元素个数

判断队列是否为空(isEmpty):判断栈是否为空,返回true/false

2.3 队列的模拟实现

Queue是一个接口,底层是通过链表来实现的(在实例化时必须实例化LinkedList)

public class MyQueue {
    static class ListNode {
        public int val;
        public ListNode prev;
        public ListNode next;

        public ListNode(int val) {
            this.val = val;
        }
    }

    ListNode head;
    ListNode tail;
    public int usedSize;

    //offer操作
    public void offer(int val) {
        ListNode node = new ListNode(val);
        if (this.head == null) {
            this.head = node;
            this.tail = node;
        } else {
            this.tail.next = node;
            this.tail = node;
        }
        this.usedSize++;
    }

    //poll操作
    public int poll() {
        if (isEmpty()) {
            return -1;//假设队列为空时返回-1,也可以抛异常
        }
        int ret = this.head.val;
        this.head = this.head.next;
        if (this.head == null) {
            this.tail = null;
        }
        this.usedSize--;
        return ret;
    }

    //peek操作
    public int peek() {
        if (isEmpty()) {
            return -1;//假设队列为空时返回-1,也可以抛异常
        }
        int ret = this.head.val;
        return ret;
    }

    //empty操作
    public boolean isEmpty() {
        return this.usedSize == 0;
    }

    //size操作
    public int size() {
        return this.usedSize;
    }
}

2.4 循环队列

环形队列通常使用数组实现,通常保留一个位置来区分空与满

判空Q.rear == Q.front

判满(Q.rear+1) % array.length == Q.front

2.5 队列OJ题

1. 用队列实现栈

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

2. 用栈实现队列

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

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

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

相关文章

【数据篇】31 # 如何对海量数据进行优化性能?

说明 【跟月影学可视化】学习笔记。 渲染动态的地理位置 用随机的小圆点模拟地图的小圆点&#xff0c;实现呼吸灯效果 最简单的做法&#xff1a;先创建圆的几何顶点数据&#xff0c;然后对每个圆设置不同的参数来分别一个一个圆绘制上去。 <!DOCTYPE html> <html …

如何使用python删除一个文件?别说,还挺好用....

嗨害大家好鸭&#xff01;我是小熊猫~ 若想利用python删除windows里的文件&#xff0c;这里需要使用os模块&#xff01;那接下来就看看利用os模块是如何删除文件的&#xff01; 具体实现方法如下&#xff01; 更多学习资料:点击此处跳转文末名片获取 os.remove(path) 删除文…

Java位运算符:Java移位运算符、复合位赋值运算符及位逻辑运算符

Java 定义的位运算&#xff08;bitwise operators&#xff09;直接对整数类型的位进行操作&#xff0c;这些整数类型包括 long&#xff0c;int&#xff0c;short&#xff0c;char 和 byte。位运算符主要用来对操作数二进制的位进行运算。按位运算表示按每个二进制位&#xff08…

GitLab安装使用(SSH+Docker两种方式)

GitLab安装使用1、在ssh下安装gitlab1.1 安装依赖1.2 配置镜像1.3 开始安装1.4 gitlab常用命令2、在docker下安装gitlab2.1 安装docker2.1.1 更新yum源2.1.2 安装依赖2.1.3 添加镜像2.1.4 查看源中可用版本2.1.5 安装指定版本2.1.6 配置开机启动项2.2 使用容器安装gitlab2.2.1 …

车载以太网 - DoIP头部信息检测逻辑 - 03

通过前面的文章我们已经了解了DoIP所具备的Payload类型,基础的信息都已经具备了,今天我们就要进一步的去了解DoIP的处理逻辑了;按照正常的逻辑来看,处理无论是我们人眼去看书,还是计算机处理一段数据,都是从前到后依次进行处理;而DoIP的信息处理也不例外,也是从头开始进…

2023跨境出海指南:印度网红营销白皮书

前不久&#xff0c;联合国预测印度人口将在4个月后超过中国&#xff0c;成为全球第一人口大国。印度这个国家虽然有些奇葩&#xff0c;但他们的经济实力确实不能小觑&#xff0c;这也是众多国际公司大力发展印度的原因。出海印度容易&#xff0c;但攻克印度市场太难&#xff0c…

Python Tutorial——类

与其它编程语言相比&#xff0c;Python的类机制添加了最小的新语法和语义。它是C和Modula-3中的类机制的混合。Python的类提供了面向对象编程的所有的标准特性&#xff0c;类继承机制允许有多个基类&#xff0c;一个子类可以重写基类中的任何方法&#xff0c;一个方法可以调用基…

编程思想图书推荐,新手入门应该看些啥

编程思想图书推荐&#xff0c;新手入门应该看些啥 导入 元旦的时候&#xff0c;学校社团的指导老师&#xff0c;咨询我有没有什么可以推荐的编程思想的学习书籍&#xff0c;可以值得推荐精读。 说实话&#xff0c;我个人是买过很多书的&#xff0c;但是很少读书&#xff0c;如果…

搭建redis主从复制+哨兵高可用

从服务器连接主服务器&#xff0c;发送SYNC命令&#xff1b;主服务器接收到SYNC命名后&#xff0c;开始执行BGSAVE命令生成RDB文件并使用缓冲区记录此后执行的所有写命令&#xff1b;主服务器BGSAVE执行完后&#xff0c;向所有从服务器发送快照文件&#xff0c;并在发送期间继续…

Window下安装oracle12C

1.Window下安装oracle12C 官网下载地址&#xff1a; Database Software Downloads | Oracle 页面顶部选择 “接受许可协议” 后&#xff0c;我想选择下载 12c 版的企业版&#xff0c;文件1和文件2都需要下载。&#xff08;如果提示登录 Oracle&#xff0c;则需要先登录才能下…

java家装网装修网站装修系统源码

简介 本平台主要是家装网站。管理员发布装修案例&#xff0c;看工地&#xff0c;装修设计师&#xff0c;装修攻略&#xff0c;装修知识文章等&#xff0c;嵌入3d全景图。普通用户注册&#xff0c;填写装修房型报价等。 演示视频&#xff1a; https://www.bilibili.com/video/…

Kotlin基础入门 - 静态变量、常量 And 静态函数、方法

2022一晃而过&#xff0c;2023悄然而至&#xff0c;有天晚上看第一行代码&#xff08;第三版&#xff09;的时候&#xff0c;又看到了Kotlin中静态方法的几种使用方式&#xff0c;蹭着过年还有一些时间&#xff0c;写了个Demo简单测试记录一下 在 Kotlin 中使用静态的方式不止一…

JavaScript基础系列之原型链

1. 前言 今天的重点复习的是JavaScript原型链。所谓是"基础不牢&#xff0c;地动山摇"&#xff0c;原型链作为继承等相关知识的基础&#xff0c;就显得尤为重要了。接下来以手绘原型链为基础&#xff0c;详解讲解下原型链以及相关的属性 2. 原型 以及原型链 2.1 pro…

vs 生成前事件 生成后事件命令

为了提高编译生成后的事件效率&#xff0c;不需要手动的拷贝到固定目录。可以在项目->属性中设备生成后事件。输入相应的命令行&#xff0c;即可。 Visual Studio中&#xff0c;可以在项目-》属性-》生成事件-》生成后事件命令行 xcopy 复制文件&#xff1b; /y/e 如果只复…

JavaEE【Spring】:MyBatis查询数据库

文章目录一、理论储备1、MyBatis 的概念2、MyBatis 的作用二、第⼀个MyBatis查询1、创建数据库和表2、添加MyBatis框架支持① 老项目添加MyBatisⅠ. 新增功能Ⅱ. EditStarters插件② 新项目添加MyBatis3、配置连接字符串和MyBatis① 配置连接字符串② 配置 MyBatis 中的 XML 路…

数据标注平台如何保护用户数据安全?

近期&#xff0c;在《麻省理工科技评论》在一篇万字长文调查中&#xff0c;一位年轻女子坐在自家的马桶上的图片也被扫地机器人拍摄下来&#xff0c;并被流传到网上、大范围传播。但事实上&#xff0c;这也并非是一件新鲜事了。例如&#xff0c;2020年秋&#xff0c;一系列从低…

为什么MySQL 要选择 B+树

一、什么是索引 在关系数据库中&#xff0c;索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构。再直白点就是我们可以把索引理解成图书或者字典的目录。 既然索引是数据的一种存储结构&#xff0c;那么我们必然要对其进行存储&#xff0c;同时&…

你可以不用Git,但不能不会Git(二)基础(上)

目录 一.环境配置 二.本地初始化仓库 三.文件的两种状态 四.文件加入暂存区 五.文件提交与删除 1.提交文件 2.删除文件 一.环境配置 当安装Git后首先要做的事情是设置用户名称和email地址。这是非 常重要的&#xff0c;因为每次Git提交都会使用该用户信息。 设置用户信…

#G. 红旗招展

Description小J占山为王有一段时间了&#xff0c;他决定把自己的地盘打扮一下---将各种颜色的旗插在山头上当然某一座的山头只能用一种颜色的旗。整个地盘有N个山头&#xff0c;可看成是一棵有N个节点的树。小J还是有一点艺术细胞的&#xff0c;他不想整个地盘杂乱无章。于是他…

Kubernetes安装ingress-controller

IngressController 1. 安装 1.1 查看ingress-nginx的版本匹配 https://github.com/kubernetes/ingress-nginx/blob/main/README.md#readme 下载配置 wget https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v1.1.2/deploy/static/provider/cloud/de…