数据结构-栈stack(链栈,顺序栈)

2024-03-08 13:08

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

一、栈的概念

1)介绍栈STL时已经有写,大家可以翻翻,传送门:点击打开链接

2)没有提过栈底,栈底:在顺序栈中指的是 -1下标,大家自己往下看嘻嘻。

二、顺序栈

1.顺序栈图解


2.特点

    1)空间有限,因为是一次性分配数组空间,有栈满情况

    2)出栈入栈是下标top变化,实际出栈只是下标后退一位实际数值还在数组中,浪费内存。

3.扔一段代码

/*顺序栈*/
#include<iostream>
using namespace std;
#define MaxSize 100
template <class T>
class Stack
{
private:T Data[MaxSize];int Top;
public :Stack();int Push(T Elem);    //入栈int Pop();          //出栈int StackEmpty();    //栈空返回1 int StackFull();     //栈满返回1int GetTop(T& TopData);   //取栈顶元素
};
template<class T>
Stack<T>::Stack() :Top(-1) {};
template<class T>
int Stack<T>::Push(T Elem)
{if (StackFull())   //栈满return 0;else{Data[++Top] = Elem;return 1;}
}
template<class T>
int Stack<T>::Pop()
{if (StackFull())   //栈空return 0;else{--Top;return 1;    //出栈成功}
}
template<class T>
int Stack<T>::StackEmpty()
{return Top == -1 ? 1 : 0;   //空返回1
}
template<class T>
int Stack<T>::StackFull()
{return Top == MaxSize - 1 ? 1 : 0;   //满返回1
}
template<class T>
int Stack<T>::GetTop(T& TopData)
{if (StackEmpty())   //栈空返回代表无栈顶值return 0;else{TopData = Data[Top];return 1;}
}

三、链栈

1.链栈图解(渣渣灵魂画手又来了)

暂停插播一句

    这个图对理解链表也有帮助,而且数据结构以链表为基础链表不熟悉自行传送门:点击打开链接

2.特点:

    1)和斐林试剂一样现(分)配现用,所以上不封顶没有栈满

    2)请时刻注意栈空是不能操作出栈和取栈顶的 :)

3.扔代码

#include<iostream>	
using namespace std;
struct Node
{int Data;Node* Next;
};
class Stack
{
private:Node * Top;   //栈顶,入栈是空间一一分配,不考虑栈满
public:Stack();      //初始栈~Stack();     //析构栈int Push(int Elem_Node);     //入栈int Pop(int& Be_Pop_Elem);     //出栈int Get_Top_Node(int& Get_Top_Elem);    //取栈底int Empty();   //判栈空
};
Stack::Stack()
{Top = NULL;
}
Stack::~Stack()
{Node* Temp_Top = Top;while (Temp_Top){Top = Top->Next;      //top不断后移,并且定义一个temp储存前方即将删除的节点delete Temp_Top;Temp_Top = Top;}
}
int Stack::Push(int Elem_Node)
{Node* Push_Node = new Node;    //创建新节点Push_Node->Next = Top;      //链接在旧栈顶前面Push_Node->Data = Elem_Node;Top = Push_Node;   //新栈顶return 1;
}
int Stack::Pop(int& Be_Pop_Elem)
{if (Top){Node* Temp_Top = Top;Be_Pop_Elem = Top->Data;Top = Top->Next;      //top后移,需要先保存旧栈顶以便删除delete Temp_Top;return 1;}elsereturn 0;
}
int Stack::Get_Top_Node(int& Get_Top_Elem)
{if (Top){Get_Top_Elem = Top->Data;return 0;}elsereturn 0;
}
int Stack::Empty()
{return Top == NULL ? 1 : 0;    //top如果是空说明栈空啦~
}

四、应用(很重要)

1)思想上:递归,例题汉诺塔,传送门:点击打开链接

2)括号匹配:点击打开链接

    应用上面顺序栈类来做下,代码如下:

int main()
{Stack<char> KuoHao;char KuoHao_str[MaxSize];int flag = 1, i = 0;char GetTop_Elem;cin >> KuoHao_str;while (flag&&KuoHao_str[i] != '\0'){switch (KuoHao_str[i]){case '[': case '(': case '{':KuoHao.Push(KuoHao_str[i]);break;case ')':KuoHao.GetTop(GetTop_Elem);if (GetTop_Elem == '(')KuoHao.Pop();elseflag = 0;break;case '}':KuoHao.GetTop(GetTop_Elem);if (GetTop_Elem == '{')KuoHao.Pop();elseflag = 0;break;case ']':KuoHao.GetTop(GetTop_Elem);if (GetTop_Elem == '[')KuoHao.Pop();elseflag = 0;break;default:break;}i++;}if (flag&&KuoHao.StackEmpty())cout << "括号匹配" << endl;elsecout << "error" << endl;return 0;

ps:就把上面类代码和实现代码放一起编译就好,怕有人懵逼

3)逆波兰表达式:点击打开链接

这篇关于数据结构-栈stack(链栈,顺序栈)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

C++实现封装的顺序表的操作与实践

《C++实现封装的顺序表的操作与实践》在程序设计中,顺序表是一种常见的线性数据结构,通常用于存储具有固定顺序的元素,与链表不同,顺序表中的元素是连续存储的,因此访问速度较快,但插入和删除操作的效率可能... 目录一、顺序表的基本概念二、顺序表类的设计1. 顺序表类的成员变量2. 构造函数和析构函数三、顺序表

JAVA利用顺序表实现“杨辉三角”的思路及代码示例

《JAVA利用顺序表实现“杨辉三角”的思路及代码示例》杨辉三角形是中国古代数学的杰出研究成果之一,是我国北宋数学家贾宪于1050年首先发现并使用的,:本文主要介绍JAVA利用顺序表实现杨辉三角的思... 目录一:“杨辉三角”题目链接二:题解代码:三:题解思路:总结一:“杨辉三角”题目链接题目链接:点击这里

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

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

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模拟实现