小白学习java理解栈手写栈——第四关(青铜挑战)

内容1.理解栈的基本特征
2.理解如何使用数组来构造栈
3.理解如何使用链表来构造栈

 1.栈的基础知识

1.1栈的特征

栈和队列是比较特殊的线性表,又称为访问受限的线性表。栈是很多表达式、符号等运算的基础,也是递归的底层实现,理论上递归能做的题目栈都可以,就是有些问题用栈回非常复杂

栈底层实现仍然是链表或者顺序表,栈于线性表的最大区别就是数据的存取的操作被限制了,其插入删除操作只允许在线性表的一段进行,一般而言,把允许操作的一端称为栈顶(Top),不可操作的一端称为栈底(Bottom),同时把插入元素的操作称为入栈(Push),删除元素的操作称为出栈(Pop)。若栈中没有任何元素,则称为空栈,栈的结构如下图:

1.2栈的操作

栈的常用操作主要有:

  •  push(E):增加一个元素E
  • pop():弹出元素E
  • peek():显示栈顶元素,但是不出栈
  • empty():判断栈是否为空

我们在设计自己的栈的时候,不管用数组还是链表,都要实现上面几个方法。

1.3Java中的栈

 Java的util中就提供了栈Stack类,使用不复杂,看一个例子就够了:

public class MainTest {public static void main(String[] args) {Stack<Integer> stack = new Stack();stack.push(1);stack.push(2);stack.push(3);System.out.println("栈顶元素为:" + stack.peek());while (!stack.empty()) {//只显示没出栈System.out.println(stack.peek());//出栈并且显示System.out.println(stack.pop());}}
}

2.基于数组实现栈

在看具体内容之前 ,先补充一个知识点,top有的地方指向栈顶元素,有的地方指向栈顶再往上的一个空单位,这个根据题目要求设计就好,本文采用指向栈顶空位置。

如果要我们自己实现栈,可以有链表、数组和java提供的LinkedList三种基本方式,我们都来写一下吧。

采用顺序表实现的栈吗,内部以数组为基础,实现对元素的存取操作。在应用中还需要注意每次入栈之前先判断栈的容量是否够用,如果不够用,可以进行扩容。

入栈过程如下: 

出栈的过程如图所示:

 

top先将栈顶元素取出来,然后再执行top--。

完整的实现代码是:

import java.util.Arrays;
class Mystack<T> {//实现栈的数组private Object[] stack;//栈顶元素private int top;Mystack() {//初始容量为10stack = new Object[10];}//判断是否为空public boolean isEmpty() {return top == 0;}//返回栈顶元素public T peek() {T t = null;if (top > 0)t = (T) stack[top - 1];return t;}public void push(T t) {expandCapacity(top + 1);stack[top] = t;top++;}//出栈public T pop() {T t = peek();if (top > 0) {stack[top - 1] = null;top--;}return t;}//扩大容量public void expandCapacity(int size) {int len = stack.length;if (size > len) {size = size * 3 / 2 + 1;//每次扩大50%stack = Arrays.copyOf(stack, size);}}public static void main(String[] args) {Mystack<String> stack = new Mystack<>();System.out.println(stack.peek());System.out.println(stack.isEmpty());stack.push("java");stack.push("is");stack.push("beautiful");stack.push("language");System.out.println(stack.pop());System.out.println(stack.isEmpty());System.out.println(stack.peek());}
}

 3.基于链表实现栈

链表也可以实现栈,插入和删除都在头结点进行就可以了。

在链表一章,我们介绍过没有虚拟结点时对链表头元素进行插入和删除的操作方法,而与这里基于链表实现栈是完全一致的。

package com.yugutou.charpter4_stack.level1;class ListStack<T> {//定义链表class Node<T> {public T t;public Node next;}public Node<T> head;//构造函数初始化头指针ListStack() {head = null;}//入栈public void push(T t) {if (t == null) {throw new NullPointerException("参数不能为空");}if (head == null) {head = new Node<T>();head.t = t;head.next = null;} else {Node<T> temp = head;head = new Node<>();head.t = t;head.next = temp;}}//出栈public T pop() {if (head == null) {return null;}T t = head.t;head = head.next;return t;}//取栈顶元素public T peek() {if (head == null) {return null;}T t = head.t;return t;}//栈空public boolean isEmpty() {if (head == null)return true;elsereturn false;}public static void main(String[] args) {ListStack stack = new ListStack();System.out.println(stack.isEmpty());stack.push("Java");stack.push("is");stack.push("beautiful");System.out.println(stack.peek());System.out.println(stack.pop());System.out.println(stack.isEmpty());}
}

 

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

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

相关文章

Linux 防病毒软件:CentOS有哪些付费的防病毒软件

CentOS是一个基于开源的Linux发行版,通常不像Windows那样普遍需要使用付费的防病毒软件。大多数Linux系统侧重于使用开源和免费的安全工具来保护系统。一些常见的免费和开源的防病毒软件和安全工具包括ClamAV、Sophos Antivirus for Linux、rkhunter、chkrootkit等。 如果你非…

python中的map函数

map() 是一个内建函数&#xff0c;用于对一个可迭代对象的每个元素应用指定的函数&#xff0c;返回一个新的可迭代对象&#xff08;通常是一个 map 对象或列表&#xff09;。 map() 函数的基本语法如下&#xff1a; map(function, iterable, ...)function: 用于处理每个元素的…

[数据集][目标检测]拉横幅识别横幅检测数据集VOC+yolo格式1962张1类别

数据集格式&#xff1a;Pascal VOC格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;1962 标注数量(xml文件个数)&#xff1a;1962 标注数量(txt文件个数)&#xff1a;1962 标注类别数&a…

Redis RedisHelper

1、添加StackExchange.Redis引用 Install-Package StackExchange.Redis -Version 2.0.601 2、封装RedisHelper using StackExchange.Redis; using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Runtime.Serialization.Form…

探索Scrapy-spider:构建高效网络爬虫

Spider简介 Scrapy中的Spider是用于定义和执行数据抓取逻辑的核心组件。Spider负责从指定的网站抓取数据&#xff0c;并定义了如何跟踪链接、解析内容以及提取数据的规则。它允许您定制化地指定要抓取的网站、页面和所需的信息。Spider的作用是按照预定的规则爬取网页&#xf…

【Rust】第一节:安装

1 说明 一些学习记录 环境&#xff1a;MacOS 2 步骤 1、执行curl --proto https --tlsv1.2 https://sh.rustup.rs -sSf | sh 2、看到打印 info: downloading installerWelcome to Rust!... ...This path will then be added to your PATH environment variable by modifyin…

边缘计算与人工智能的融合

随着物联网技术的迅猛发展&#xff0c;大量设备和传感器开始连接至互联网&#xff0c;产生了海量的数据。传统的云计算模式往往无法满足对数据实时性和隐私保护的需求&#xff0c;而边缘计算技术的兴起为解决这一难题提供了新的思路。边缘计算将数据处理和分析的功能下沉至数据…

Python作业答疑_6.22~6.25

一、Python 一班 1. 基数分割列表 1.1 问题描述 给定一无序数列&#xff0c;把数列的第一个数字当成基数&#xff0c;让数列中基数小的数字排在数列前面&#xff0c;比基数大的数字排在数列的后面。 1.2 问题示例 如数列&#xff1a;num[4,1,8,3,9,2,10,7]。基数为 4&…

产品成本收集器流程演示

感谢大佬的文章&#xff0c;我只是一个翻译搬运工&#xff0c;原文地址&#xff1a;产品成本收集器 概述 SAP 令人兴奋的部分之一是它在不同操作模块之间的集成程度。使用产品成本收集器来跟踪生产就是一个很好的例子。在本博客中&#xff0c;我计划遵循产品成本收集器流程&a…

JAVA刷题之数组的总结和思路分享

꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好&#xff0c;我是xiaoxie.希望你看完之后,有不足之处请多多谅解&#xff0c;让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN …

C语言第十六集(前)

1.关于那个整形存储入char的 是先取好补码,再截断 例: 2.%u是以十进制的形式打印无符号整数 3.注意(背):存储的char类型变量的补码为10000000的直接解析为-128 4.signed char 类型的变量取值范围是-128~127 5.unsigned char 类型的变量取值范围是0~255 6.有符号类型的变量…

2023.12.6 关于 Spring Boot 事务的基本概念

目录 事务基本概念 前置准备 Spring Boot 事务使用 编程式事务 声明式事务 Transactional 注解参数说明 Transational 对异常的处理 解决方案一 解决方案二 Transactional 的工作原理 面试题 Spring Boot 事务失效的场景有那些&#xff1f; 事务基本概念 事务指一…

如何解决5G基站高能耗问题?

安科瑞 须静燕 截至2023年10月&#xff0c;我国5G基站总数达321.5万个&#xff0c;占全国通信基站总数的28.1%。然而&#xff0c;随着5G基站数量的快速增长&#xff0c;基站的能耗问题也逐渐日益凸显&#xff0c;基站的用电给运营商带来了巨大的电费开支压力&#xff0c;降低5…

vue项目配置多个代理

在本地.env文件配置本地/测试/预发/正式 路径&#xff1a; 在vue.config.js 里面配置&#xff1a; module.exports defineConfig({transpileDependencies: false,lintOnSave: false,outputDir: process.env.VUE_APP_DIST,publicPath: /,css: {loaderOptions: {postcss: {// p…

Motion Plan之轨迹生成代码实现 (1)

Motion Plan之搜索算法笔记Motion Plan之基于采样的路径规划算法笔记Motion Plan之带动力学约束路径搜索 Motion Plan之轨迹生成笔记文章开始前先回顾下上次的带约束的轨迹生成&#xff0c;轨迹生成本质就是曲线拟合。曲线拟合常用的方法有&#xff1a;多项式、贝赛尔曲线、三…

“Notification.recipient“ must be a “User“ instance.

使用django的通知模块报错&#xff1a; Lib\site-packages\notifications\base\models.py class AbstractNotification(models.Model):recipient models.ForeignKey(settings.AUTH_USER_MODEL,on_deletemodels.CASCADE,related_namenotifications,verbose_name_(recipient),b…

第5节:Vue3 JavaScript 表达式

在 Vue3 中&#xff0c;JavaScript 表达式的使用方式与 Vue2 有所不同。 在 Vue3 中&#xff0c;你可以使用 v-bind 指令来绑定 JavaScript 表达式。例如&#xff1a; <template><div>{{ count }}</div> </template><script> import { ref } f…

CPU密集型和IO密集型与CPU内核之间的关系

CPU密集型和IO密集型与CPU内核之间的关系 一、CPU密集型 介绍 CPU密集型&#xff0c;也叫计算密集型&#xff0c;是指需要大量CPU计算资源&#xff0c;例如大量的数学运算、图像处理、加密解密等。这种类型的任务主要依赖于CPU的计算能力&#xff0c;会占用大量的CPU时间片&am…

vcomp140.dll文件丢失解决方法分享:三种亲测有效方案

在计算机使用过程中&#xff0c;我们经常会遇到一些错误提示&#xff0c;其中之一就是“vcomp140.dll丢失”。这个错误提示通常出现在运行某些程序或游戏时&#xff0c;给使用者带来了很大的困扰。那么&#xff0c;vcomp140.dll丢失怎样修复呢&#xff1f;本文将详细介绍解决这…

Spark低版本适配Celeborn

Spark-3.5版本以下使用Celeborn时&#xff0c;无法使用动态资源&#xff0c;对于低版本的Spark&#xff0c;Celeborn提供了patch。各版本patch如下 https://github.com/apache/incubator-celeborn/tree/main/assets/spark-patch 下载patch&#xff0c;这里下载spark-3版本&am…