数据结构(三)——线性结构之栈Stack

2024-03-31 19:58

本文主要是介绍数据结构(三)——线性结构之栈Stack,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.栈是限定仅在表头进行插入和删除操作的线性表。

   栈在中断处理特别是重要数据的现场保护有着重要意义。

   栈相当于一个箱子,然后往箱子里一层一层的放东西,最先放的最后取,先进后出。

   入口的一端为栈顶,另一端称作栈底。向一个栈插入新元素又称作进栈、入栈或压栈,它是把新元素放到栈顶元素的上面,使之成为新的栈顶元素;从一个栈删除元素又称作出栈或退栈,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

2.从数据存储结构来划分,栈可以分为两类:

  • 顺序栈结构:即使用一组地址连续的内存单元依次保存栈中的数据。在程序中,可以定义一个指定大小的结构数组来作为栈,序号为0的元素就是栈底,在定义一个变量top保存栈顶的序号即可。
  • 链式栈结构,即使用链表形式保存栈中各元素的值,链表首部(head引用所指向元素)为栈顶,链表尾部(指向地址为null)为栈底。

3.对栈的操作

本次操作我们考虑的是顺序栈结构的操作,我们可以把栈想像成一个数组,每次插入插入在数组的最后一位,取也从最后一位来取。

栈主要的操作有以下几个:

(1)入栈(Push)(也称压栈):将数据保存到栈顶的操作;

(2)出栈(Pop):将栈顶的数据弹出的操作;

(3)查看栈顶元素;

(4)判断栈是否为空。

package cn.kimtian.array.stack;import java.util.Arrays;/*** 对栈的操作* 由于栈有先进后出的特性* 所以我们考虑若 每次为数组增加元素,加在数组的最后一位,每次取数据也从数组的最后一位取。* 就保证了先进后出。实现了栈的特性。** @author kimtian*/
public class MyStack {/*** 栈的底层我们使用数组来存储数据*/int[] elements;public MyStack() {elements = new int[0];}/*** 压入元素方法** @param element 入栈数据*/public void pushStack(int element) {// 创建一个新的数组int[] newArr = new int[elements.length + 1];// 把原数组中的元素复制到新的数组中for (int i = 0; i < elements.length; i++) {newArr[i] = elements[i];}// 把添加的元素放入新数组中newArr[elements.length] = element;// 使用新数组替换老数组elements = newArr;}/*** 取出栈顶元素*/public int popStack() {// 栈是空的if (elements.length == 0) {throw new RuntimeException("stack is empty!");}// 取出数组的最后一个元素int element = elements[elements.length - 1];// 创建一个新的数组int[] newArr = new int[elements.length - 1];// 把原数组中除了最后元素的其他元素都放入新数组中for (int i = 0; i < newArr.length; i++) {newArr[i] = elements[i];}// 使用新数组替换老数组elements = newArr;// 返回栈顶元素return element;}/*** 查看栈顶元素*/public int peekStack() {// 栈是空的if (elements.length == 0) {throw new RuntimeException("stack is empty!");}// 取出数组的最后一个元素int element = elements[elements.length - 1];return element;}/*** 判断栈是否为空*/public boolean isStackEmpty() {return elements.length == 0;}
}

 

这篇关于数据结构(三)——线性结构之栈Stack的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/865205

相关文章

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现

自定义类型:结构体(续)

目录 一. 结构体的内存对齐 1.1 为什么存在内存对齐? 1.2 修改默认对齐数 二. 结构体传参 三. 结构体实现位段 一. 结构体的内存对齐 在前面的文章里我们已经讲过一部分的内存对齐的知识,并举出了两个例子,我们再举出两个例子继续说明: struct S3{double a;int b;char c;};int mian(){printf("%zd\n",s

线性因子模型 - 独立分量分析(ICA)篇

序言 线性因子模型是数据分析与机器学习中的一类重要模型,它们通过引入潜变量( latent variables \text{latent variables} latent variables)来更好地表征数据。其中,独立分量分析( ICA \text{ICA} ICA)作为线性因子模型的一种,以其独特的视角和广泛的应用领域而备受关注。 ICA \text{ICA} ICA旨在将观察到的复杂信号

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

OpenCV结构分析与形状描述符(11)椭圆拟合函数fitEllipse()的使用

操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C++11 算法描述 围绕一组2D点拟合一个椭圆。 该函数计算出一个椭圆,该椭圆在最小二乘意义上最好地拟合一组2D点。它返回一个内切椭圆的旋转矩形。使用了由[90]描述的第一个算法。开发者应该注意,由于数据点靠近包含的 Mat 元素的边界,返回的椭圆/旋转矩形数据

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

✨机器学习笔记(二)—— 线性回归、代价函数、梯度下降

1️⃣线性回归(linear regression) f w , b ( x ) = w x + b f_{w,b}(x) = wx + b fw,b​(x)=wx+b 🎈A linear regression model predicting house prices: 如图是机器学习通过监督学习运用线性回归模型来预测房价的例子,当房屋大小为1250 f e e t 2 feet^