iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >Java数据结构01——栈
  • 794
分享到

Java数据结构01——栈

数据结构java开发语言 2023-09-20 17:09:06 794人浏览 泡泡鱼
摘要

一、栈         1、栈的性质                 栈(stack)是限定仅在表尾进行插入或者删除的线性表。对于栈来说,表尾端称为栈顶(top),表头端称为栈低(bottom)。不含元素的空表称为空栈。因为栈限定在表尾进行

一、栈

        1、栈的性质

                栈(stack)是限定仅在表尾进行插入或者删除的线性表。对于栈来说,表尾端称为栈顶(top),表头端称为栈低(bottom)。不含元素的空表称为空栈。因为栈限定在表尾进行插入或者删除,因此栈又被称为先进后出(后进先出)的线性表(简称LIFO结构)。

二、Java实现 

        1、功能分析

                对于一个栈首先是向数据结构中添加元素和删除元素因此需要push入栈 以及pop出栈。

同时也需要一个能够遍历栈的函数。

        2、代码实现

                (1)、初始化

public class Stack {    //使用arrayList来保存元素,并作为栈的数据结构    ArrayList array = new ArrayList();    //空参构造器    public Stack(){}}

分析:此处使用Java内置的ArrayList作为数据存储的结构,并存储整型数据。

                (2)、入栈

public void push(int data){        array.add(data);    }

分析:依据ArrayList的性质,可以直接调用其中的add方法进行入栈操作。

               

                 (3)、出栈

 public void pop(){        //判断栈是否为空        if(array.size() == 0){            System.out.println("栈为空");        }else {            System.out.println(array.get(array.size() - 1));            array.remove(array.size() - 1);        }    }

分析:在进行出栈操作时,需要先判断栈是否为空,当栈为空时需要捕获异常。当栈内有元素时将从ArrayList的尾部输出元素,通过该方法实现栈的先进后出性质

                (4)、遍历

 public void travel(){        for (int i = 0; i < array.size(); i++) {            System.out.println(array.get(i));        }    }

分析:此处即遍历ArrayList的方法。

三、栈的拓展

        1、简述

                上述栈的结构只能保存整型的数据,因此这种类型的数据结构普适性很差。因此我们需要创建一个能够保存任何结构的数据。在Java中即需要使栈能够保存对象。结合之前所说的泛型数组,我们将要对上述栈进行改造。关于泛型数组可以查看博客:

泛型数组:(96条消息) Java数组(2)_️771的博客-CSDN博客

        2、代码实现

                (1)、创建栈类

public Stack{}

分析:当我们需要创建一个泛型类的话只需要在类名后面声明其性质

                (2)、创建节点类

public Stack{        class node{        //数据        Object data;        //节点指向        Node  nextNode;        //节点有参构造器        public Node(E data){            //保存当前节点的数据            this.data = data;            //设置节点指向            this.nextNode = null;        }   }}

分析:此处在栈类中包含了一个节点类,该类用于存储当前节点的数据以及指向下一个节点。

                (3)、方法实现

push入栈
pop出栈

                     入栈

public void push(E data){        //判断栈是否为空并执行相应操作        if (front == null) {            front = new Node<>(data);            front.nextNode = null;        }        //栈内有元素时相应操作        else {            Node temp = front;            front = new Node<>(data);            front.nextNode = temp;        }    }

分析:该方法需要从外界接受参数,根据定义栈的数据类型,传入值为泛型,之后需要判断栈是否为空。当栈为空时我们需要设置栈顶元素并设置指向下一个元素 为空。当栈内存在元素时,首先要创建一个临时变量用于保存传入值,并将栈尾元素的节点指向这个临时节点。  

              出栈

public void pop(){        //创建输出变量        E data = front.data;        //去除已经出栈的元素        front = front.nextNode;        System.out.println(data);    }

分析:先从栈尾获取元素,并将下一个对象的节点指向该对象。

(本章用最简单的数据结构实现栈,内容持续更新)

来源地址:https://blog.csdn.net/qq_64037280/article/details/128884264

--结束END--

本文标题: Java数据结构01——栈

本文链接: https://www.lsjlt.com/news/413104.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java数据结构01——栈
    一、栈         1、栈的性质                 栈(stack)是限定仅在表尾进行插入或者删除的线性表。对于栈来说,表尾端称为栈顶(top),表头端称为栈低(bottom)。不含元素的空表称为空栈。因为栈限定在表尾进行...
    99+
    2023-09-20
    数据结构 java 开发语言
  • java数据结构基础:栈
    目录准备工作编码环节push方法pop方法empty方法全部代码总结准备工作 工具:idea+jdk8 技术要求:java基础语法 编码环节 首先,我们得先确定下来,用什么数据来模拟...
    99+
    2022-11-12
  • 【数据结构】Java实现栈
    目录 1. 概念 2. 栈的使用  3. 自己动手实现栈(使用动态数组实现栈)  1. 创建一个MyStack类 2. push入栈 3. pop出栈 4. 查看栈顶元素 5. 判断栈是否为空与获取栈长 6. toString方法 4. 整...
    99+
    2023-10-27
    数据结构 jvm java
  • 疯狂数据结构-栈-Java
    概念 基本概念解读 当谈到 "栈" 时,它是一种遵循后进先出(Last In, First Out,LIFO)原则的有序集合。这意味着最后入栈的元素首先被弹出,而最早入栈的元素最后被弹出。在栈中,只能对最上面的元素进行操作,其他元素都不可见...
    99+
    2023-08-16
    数据结构 java 开发语言
  • Java数据结构之栈的线性结构详解
    目录一:栈二:栈的实现三:栈的测试四:栈的应用(回文序列的判断)总结一:栈 栈是限制插入和删除只能在一个位置上进行的表,此位置就是表的末端,叫作栈顶。 栈的基本操作分为push(入...
    99+
    2022-11-12
  • 数据结构(二):栈
    栈:后进先出(LIFO)表。 特点:只允许在顶部进行存取操作的顺序表。 基本操作: push:入栈,即将元素压入栈顶 pop:出栈,即将栈顶元素删除 top:输出栈顶元素 应用场景: 平衡符号:编译器中用于检查符号是否成对出现,方...
    99+
    2023-01-31
    数据结构
  • java数据结构之栈的详解
    目录一、栈1.栈的应用1.1括号匹配1.2后缀表达式1.3用栈实现队列1.4最小栈1.5栈的压入和弹出序列总结一、栈 栈的特性就是先进后出,常用方法是入栈(push()),出栈(po...
    99+
    2022-11-12
  • java 数据结构之栈与队列
    java 数据结构之栈与队列一:对列队列是一种先进先出的数据结构实现代码:package Queue; public class Queue { //队列类 private int maxSize; //定义队列的长度 ...
    99+
    2023-05-31
    java 队列
  • java数据结构中栈怎么应用
    本篇内容主要讲解“java数据结构中栈怎么应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“java数据结构中栈怎么应用”吧!声明一个栈接口SStackpackage ch05;&nb...
    99+
    2023-06-22
  • Java数据结构学习之栈和队列
    目录一、栈1.1 概述1.1.1 线性表的概念1.1.2 栈的概念1.1.3 栈的应用二、队列2.1 队列的概念2.2 队列的实现2.3 队列的应用一、栈 1.1 概述 Java为什...
    99+
    2022-11-12
  • Java语言如何实现数据结构栈
    这篇文章主要介绍了Java语言如何实现数据结构栈,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。首先了解下栈的概念:栈是限定仅在表头进行插入和删除操作的线性表。有时又叫LIFO...
    99+
    2023-05-30
    java
  • 【数据结构】栈与队列
    作者主页:paper jie 的博客 本文作者:大家好,我是paper jie,感谢你阅读本文,欢迎一建三连哦。 本文录入于《JAVA数据结构》专栏,本专栏是针对于大学生,编程小白精心打造的。笔者用重金(时间和精力)打造,将java...
    99+
    2023-10-23
    数据结构 java 开发语言
  • 数据结构——栈(C语言)
    需求:无 栈的概念: 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端为栈底。栈中的数据元素遵守后进先出(LIFO)原则。压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈...
    99+
    2023-09-04
    数据结构 c语言 经验分享
  • 【数据结构-链表-01】反转链表
    💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,...
    99+
    2023-08-30
    算法
  • java数据结构基础:循环链表和栈
    目录循环链表:实现思路:代码实现:栈:实现思路:代码实现:总结循环链表: 与单链表的最后一个节点的指针域为null不同,循环链表的最后一个节点的指针指向头结点 实现思路: 初始化时将...
    99+
    2022-11-12
  • java数据结构关于栈的实例应用
    此文章介绍关于顺序栈,链式栈的实例操作,括号匹配,表达式求值(后缀表达式) 1.声明一个栈接口SStack package ch05; public interface SS...
    99+
    2022-11-12
  • Python数据结构之栈详解
    目录0. 学习目标1. 栈的基本概念1.1 栈的基本概念1.2 栈抽象数据类型1.3 栈的应用场景2. 栈的实现2.1 顺序栈的实现2.1.1 栈的初始化2.2 链栈的实现2.3 栈...
    99+
    2022-11-13
  • Java 数据结构与算法系列精讲之栈
    目录概述栈栈实现push方法pop方法main完整代码概述 从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章. 栈 栈 (Stack) 是一种运算受限...
    99+
    2022-11-13
  • Java数据结构之栈与队列实例详解
    目录一,栈1,概念2,栈的操作3,栈的实现 4,实现mystack二,队列1,概念 2,队列的实现 3,实现myqueue栈、队列与数组的区别?总结 一,栈 1,概念 在我们软件应用...
    99+
    2022-11-12
  • 带你了解Java数据结构和算法之栈
    目录1、栈的基本概念2、Java模拟简单的顺序栈实现  3、增强功能版栈4、利用栈实现字符串逆序5、利用栈判断分隔符是否匹配  6、总结1、栈的基本概念 栈(英语:stack)又称为...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作