数据结构 模拟实现Stack栈(数组模拟)

目录

一、栈的概念

二、栈的接口

三、栈的方法实现

(1)push方法

(2)pop方法

(3)peek方法

(4)size方法

​编辑

(5)empty方法

四、最终代码


一、栈的概念

概念:栈是一种先进后出的数据结构,类似羽毛球桶,先放进去的羽毛球,后面才能拿出来        如图:

还有弹匣,先放进去的子弹后面发射出去,如图:

我们定义一个自己的栈类,里面有数组,存放数据,还有一个变脸usedSize,记录栈里的元素个数,带有构造方法,不带参数的给数组默认初始化10个元素,带参数就初始化你想要的元素个数,代码如下:

public class MyStack implements IStack{

    private int[] elem;
    private int usedSize;
    private int DEFAULT_CAPACITY = 10;

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

二、栈的接口

代码如下:

public interface IStack {
    public void push(int x);
    public int  pop();
    public int peek();
    public int size();
    public boolean empty();
}

三、栈的方法实现

(1)push方法

此方法是放元素进栈里面,也就是入栈,因为我们有记录栈元素个数的usedSize变量,所以我们可以用这个变量充当入栈时,要放进elem数组的哪个下标,因为usedSize记录的栈的个数,在数组中对应的下标就是个数-1;

入栈前,要检查栈是否满了,满了就要扩容,没满就给elem数组的usedSize-1下标位置放入元素,放完后usedSize++。代码如下:

    public void push(int x) {
        if(full()) {
            //扩容
            elem = Arrays.copyOf(elem, elem.length * 2);
        }
        elem[usedSize++] = x;
    }
    private boolean full() {
        return usedSize == elem.length;
    }

执行效果如下:

elem数组里面有3个数,正好是我们入栈的元素。

(2)pop方法

此方法是出栈方法,取出栈顶元素,取完后就删除栈顶元素;在取出栈顶元素前,要检查栈是否为空,如果是空就要抛异常,因为没有元素可以出栈了;如果栈不为空,就出栈顶元素,也就是取出elem数组下标为usedSize-1的位置,然后usedSize--,代码如下:

    public int pop() {
        if(usedSize == 0) {
            throw new EmptyException("栈空了");
        }
        int tmp = elem[usedSize - 1];
        usedSize--;
        return tmp;
    }
//异常类
public class EmptyException extends RuntimeException{
    public EmptyException(String msg) {
        super(msg);
    }
}

执行效果如下:

里面有元素的时候就正常出栈,空了就会抛异常。

(3)peek方法

peek翻译成中文就是瞄一眼的意思,此方法也是就拿到栈顶元素,但不会删掉栈顶的元素,里面的操作和pop一样,但不会usedSize--,代码如下:

    public int peek() {
        if(usedSize == 0) {
            throw new EmptyException("栈空了");
        }
        int tmp = elem[usedSize - 1];
        return tmp;
    }

执行效果如下:

一直打印的都是栈顶元素,说明没有出栈顶元素,只是拿栈顶元素。

(4)size方法

此方法是获取栈里的元素,所以这里直接返回usedSize就好了,代码如下:

    public int size() {
        return usedSize;
    }

执行效果如下:

(5)empty方法

此方法是判断栈是不是空的,所以直接判断usedSize==0就好了,返回这个表达式的结果,代码如下:

    public boolean empty() {
        return usedSize == 0;
    }

执行效果如下:


四、最终代码

//接口类
public interface IStack {
    public void push(int x);
    public int  pop();
    public int peek();
    public int size();
    public boolean empty();
}

//自定义MyStack类
public class MyStack implements IStack{

    private int[] elem;
    private int usedSize;
    private int DEFAULT_CAPACITY = 10;

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

    @Override
    public void push(int x) {
        if(full()) {
            //扩容
            elem = Arrays.copyOf(elem, elem.length * 2);
        }
        elem[usedSize++] = x;
    }
    private boolean full() {
        return usedSize == elem.length;
    }

    @Override
    public int pop() {
        if(usedSize == 0) {
            throw new EmptyException("栈空了");
        }
        int tmp = elem[usedSize - 1];
        usedSize--;
        return tmp;
    }

    @Override
    public int peek() {
        if(usedSize == 0) {
            throw new EmptyException("栈空了");
        }
        int tmp = elem[usedSize - 1];
        return tmp;
    }

    @Override
    public int size() {
        return usedSize;
    }

    @Override
    public boolean empty() {
        return usedSize == 0;
    }
}

//自定义异常类
public class EmptyException extends RuntimeException{
    public EmptyException(String msg) {
        super(msg);
    }
}

都看到这了,点个赞再走吧,谢谢谢谢谢!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

我们公司内应届生身上的6个共性问题

如题目,本文主要是根据我们公司内真实的应届生身上共同的问题,总结而来。 1. 一天会做很多工作:会跟很多人对接,会一会忙这个一会忙哪个 现象: 说实话,这种情况,我看着都替她着急。自己正在解…

【2058错误】sql软件链接数据库 mysql 报错误2058

【2058错误】sql软件链接数据库报错误2058 操作:仅需在mysql登陆之后运行一行代码即可:注意1.后面必须是%,而不是别人说的 localhost2.此处的password是你自己的mysql密码。 操作:仅需在mysql登陆之后运行一行代码即可&#xff1a…

jQuery页面整屏滚动

效果展示 jQuery页面整屏滚动 Html代码块 <div id"fullpage" class"fullpage-index"><!-- index01 --><div class"indexitem index01 section" id"#page1"><img src"img/img01.jpg"/></div>…

关于kthread_stop的疑问(linux3.16)

线程一旦启动起来后&#xff0c;会一直运行&#xff0c;除非该线程主动调用do_exit函数&#xff0c;或者其他的进程调用kthread_stop函数&#xff0c;结束线程的运行。 之前找销毁内核线程的接口时&#xff0c;发现了kthread_stop这个接口。网上说这个函数能够销毁一个内核线程…

124 二叉树中的最大路径和

又是一个hard题目&#xff0c;其实我大概有想到要去dfs遍历节点&#xff0c;当时不知道怎么从一个叶子结点开始遍历。其实只需要从根节点出发&#xff0c;看看左右节点加在一起是否最大能不能作为一个路径&#xff0c;但是对外这是要不左节点上来要不右节点上来&#xff0c;不能…

LeetCode(40)组合总和Ⅱ⭐⭐

给定一个候选人编号的集合 candidates 和一个目标数 target &#xff0c;找出 candidates 中所有可以使数字和为 target 的组合。 candidates 中的每个数字在每个组合中只能使用 一次 。 注意&#xff1a;解集不能包含重复的组合。 示例 1: 输入: candidates [10,1,2,7,6,…

热图分析(这个热力图代表的是不同描述符与pIC50之间的皮尔逊相关系数。)

案例一&#xff1a; 这个热力图代表的是不同描述符与pIC50之间的皮尔逊相关系数。pIC50是一种表示化合物在生物学测定中抑制效果的负对数IC50值&#xff0c;它通常用于药物发现和评估中&#xff0c;用来量化化合物对特定靶标的抑制能力。 要分析这个热力图&#xff0c;你需要关…

vue3-admin-element框架实现动态路由(根据接口返回)

第一步&#xff1a;在src-utils-handleRoutes&#xff0c;修改代码&#xff1a; export function convertRouter(routers) {let array [];for (let i in routers) {for (let s in asyncRoutes) {if (routers[i].path asyncRoutes[s].path) {array.push({ ...asyncRoutes[s] …

CNN——GoogLeNet

1.GoogLeNet简介 GoogLeNet是谷歌推出的基于Inception模块深度卷积神经网络结构。L和N大写还是为了致敬LeNet。在随后的两年中一直在改进&#xff0c;形成了Inception V2、Inception V3、Inception V4等版本。GoogLeNet&#xff08;Inception-V1&#xff09;&#xff0c;在Imag…

鸿蒙学习笔记

DevEco Studio, ArkTS, ArkUI, ArkCompiler, DevEco Testing是啥 DevEco Studio是华为开发的一款集成开发环境&#xff08;IDE&#xff09;&#xff0c;用于开发基于华为鸿蒙操作系统&#xff08;HarmonyOS&#xff09;的应用程序。它提供了丰富的开发工具和功能&#xff0c;包…

武汉灰京文化:技术先锋辐射游戏行业,带来全新体验乐趣无穷!

科技的持续演进&#xff0c;给游戏产业打了强心剂&#xff0c;让这个领域变得前所未有的越来越好玩儿。今天我们将深入探讨如何利用虚拟现实&#xff08;VR&#xff09;和增强现实&#xff08;AR&#xff09;技术&#xff0c;让你玩得开心&#xff0c;玩得尽兴。 想象一下&…

在pycharm中jupyter连接上了以后显示无此库,但是确实已经安装好了某个库,使用python可以跑,但是使用ipython就跑不了

今天遇到一个事情&#xff0c;就是用pycharm的jupyter时&#xff0c;连接不上&#xff0c;后来手动连接上了以后&#xff0c;发现环境好像不对。 一般来说&#xff0c;这里会是python3&#xff0c;所以里面的环境也是普通python的环境&#xff0c;并没有我下载的库&#xff0c;…

计算机毕业设计-----SSM餐厅点餐收银管理系统

项目介绍 用于餐厅的收银管理系统&#xff0c;包含了四个模块 1.桌位模块 桌位模块主要是用于管理桌位的模块&#xff0c;包括点菜到结账的流程 将桌位人数设置为0可以滞空当前桌位 2.账单模块 账单模块记录了每一天的帐单汇总&#xff0c;同时提供了年月日账单的统计&#x…

mysql之CRUD和常见函数和UNION 和 UNION ALL

mysql之CRUD和常见函数和UNION 和 UNION ALL 一.CRUD1.创建&#xff08;Create&#xff09; - 插入数据2.读取&#xff08;Read&#xff09; - 查询数据3.更新&#xff08;Update&#xff09; - 修改数据4.删除&#xff08;Delete&#xff09; - 删除数据 二.函数1.字符串函数&…

二刷Laravel 教程(构建页面)总结Ⅰ

L01 Laravel 教程 - Web 开发实战入门 ( Laravel 9.x ) 一、功能 1.会话控制&#xff08;登录、退出、记住我&#xff09; 2.用户功能&#xff08;注册、用户激活、密码重设、邮件发送、个人中心、用户列表、用户删除&#xff09; 3.静态页面&#xff08;首页、关于、帮助&am…

五、Spring AOP面向切面编程(基于XML方式实现)

本章概要 Spring AOP基于XML方式实现(了解)Spring AOP对获取Bean的影响理解 根据类型装配 bean使用总结 5.6 Spring AOP基于XML方式实现(了解) 准备工作 加入依赖 <!-- spring-aspects会帮我们传递过来aspectjweaver --> <dependency><groupId>org.spr…

Langchain模板-LangChainTemplates 讲解及应用

langchain官方链接&#xff1a;https://github.com/langchain-ai/langchain/tree/master/templates 其他相关链接&#xff1a; https://python.langchain.com/docs/templates https://templates.langchain.com/ Langchain模板&#xff0c;提供一系列的易于部署的参考架构&a…

基于 Python+Django 技术栈,我开发了一款视频管理系统

学习过程中&#xff0c;遇到问题可以咨询作者 大家好&#xff0c;作为一名开发人员&#xff0c;平时比较愿意动手尝试各种有意思工具&#xff0c;因为笔者非常喜欢观看视频&#xff0c;尤其是YouTube、bilibili都是笔者非常喜欢的视频网站&#xff0c;所以想自己实现一个视频点…

Java/JDK下载安装与环境配置

Java由Sun Microsystems&#xff08;现在是Oracle的子公司&#xff09;于1995年首次发布。它是一种面向对象的编程语言&#xff0c;广泛应用于Web开发、移动应用程序开发、桌面应用程序开发和企业级应用程序开发等领域。 Java语言的主要特点是跨平台、可移植性强、安全性高和具…

代码随想录-刷题第四十八天

198. 打家劫舍 题目链接&#xff1a;198. 打家劫舍 思路&#xff1a;当前房屋偷与不偷取决于前一个房屋和前两个房屋是否被偷了。这里就更感觉到&#xff0c;当前状态和前面状态会有一种依赖关系&#xff0c;那么这种依赖关系都是动规的递推公式。动态规划五步曲&#xff1a;…
最新文章