首页 > 编程语言 >C++数据结构之:栈Stack

C++数据结构之:栈Stack

时间:2024-05-31 09:34:15浏览次数:27  
标签:node CStackNode top NULL C++ stack push 数据结构 Stack

摘要:

   it人员无论是使用哪种高级语言开发东东,想要更高效有层次的开发程序的话都躲不开三件套:数据结构,算法和设计模式。数据结构是相互之间存在一种或多种特定关系的数据元素的集合,即带“结构”的数据元素的集合,“结构”就是指数据元素之间存在的关系,分为逻辑结构和存储结构。

   此系列专注讲解数据结构数组、链表、队列、栈、树、哈希表、图,通过介绍概念以及提及一些可能适用的场景,并以C++代码简易实现,多方面认识数据结构,最后为避免重复造轮子会浅提对应的STL容器。本文介绍的是栈Stack。

(开发环境:VScode,C++17)

关键词C++数据结构Stack

声明:本文作者原创,转载请附上文章出处与本文链接。

文章目录

正文:

介绍:

   栈(Stack)是一种后进先出(LIFO,Last In First Out)的数据结构,它只允许在一端进行操作或删除操作,这一端被称为栈顶(Top),而另一端则被称为栈底(Bottom)。

在这里插入图片描述

   栈也有两种存储表示方法:链栈和顺序栈。链栈是指采用链式存储结构实现的栈,通常用单链表来表示。它的特点是:用一组任意的存储单元存储线性表的数据元素(这组存储单元可以是连续也可以是不连续);而顺序栈是用顺序存储结构实现的栈,利用一组地址连续的存储单元依次存放自栈底到栈顶的数据元素。

特性:
  • 后进先出(LIFO):栈中的元素按照先后顺序排列,最后一个进入的元素总是在栈顶,而第一个进入的元素在栈底。每次删除(或称为弹出)操作都是取出栈顶的元素,因此栈是一种后进先出的数据结构。
  • 单端插入/删除:栈只允许在栈顶进行插入(压入,Push)和删除(弹出,Pop)操作。
  • 受限的随机访问:栈中的元素只能通过栈顶进行访问,而不能直接访问栈底或其他位置的元素。
  • 适用于简单的数据结构:栈只具有插入和删除元素的功能,不支持排序和查找等操作。
应用:
  • 函数调用:在函数调用时,栈用于保存函数的返回地址和局部变量。当函数调用结束时,栈顶指针会回退到上一个函数的位置。
  • 括号匹配:使用栈可以轻松解决括号匹配的问题。通过遍历表达式,将左括号压入栈中,当遇到右括号时,从栈顶弹出一个元素并判断是否与当前右括号匹配。
  • 表达式求值:栈可以用来实现中缀表达式转后缀表达式,并且可以通过后缀表达式求解表达式的值。
  • 浏览器前进后退:浏览器的前进和后退功能可以使用两个栈来实现,分别保存浏览历史记录。
  • 撤销操作:在编辑器或办公软件中,撤销操作通常可以使用栈来实现,将每次的操作记录压入栈中,当需要撤销时从栈顶弹出一个操作并执行相反的操作。
代码实现:
#cstack.h
#ifndef CSTACK_H
#define CSTACK_H
#include <iostream>
using namespace std;

// 栈链节点
template<class T>
class CStackNode
{
public:
    CStackNode(T t):data(t),next(NULL){}
    ~CStackNode(){ next = NULL; }
    CStackNode(const CStackNode& node)
    {
        if(this == &node){
            return;
        }
        *this = node;
    }
    CStackNode &operator=(const CStackNode& node)
    {
        if (this == &node){
            return *this;
        }
        this->data = node.data;
        this->next = node.next;
        return *this;
    }
    
public:
    T data;
    CStackNode *next;
};


// 链式栈
template<class T>
class CStack
{
public:
    CStack() :top(NULL),node(NULL),m_size(0) {}
    ~CStack()
    {
        delete top;top = NULL;
        delete node;node = NULL;
    }

    void push(T t);                     // 入栈
    T pop();                            // 出栈
    void traverse();                    // 打印整个栈
    void clear();                       // 清空栈
    T getTop() { return top; }          // 返回栈顶元素
    int size() { return m_size; }       // 返回栈内成员个数
    bool empty() { return 0 == m_size; }// 判断是否为空栈

private:
    CStackNode<T>* top;     
    CStackNode<T>* node;      
    int m_size; 
};

template <class T>
inline void CStack<T>::push(T t)
{
    node = new CStackNode<T>(t);
    if(top == NULL){
        top = node;
    }
    else{
        node->next = top;
        top = node;
    }
    m_size++;
}

template <class T>
inline T CStack<T>::pop()
{
    if(empty()){
        throw "empty stack.";
    }
    node = top;
    top = top->next;
    m_size--;
    return node->data;
}

template <class T>
inline void CStack<T>::traverse()
{
    node = top;
    while (node != NULL)
    {
        cout << node->data << " ";
        node = node->next;
    }
    cout << endl;
}

template <class T>
inline void CStack<T>::clear()
{
    node = top;
    while (node != NULL)
    {
        node = top->next;
        delete top;
        top = node;
    }
    top = NULL;
    m_size = 0 ;
}

#endif // !CSTACK_H
#cstack.cpp
#include "cstack.h"
#include <iostream>
using namespace std;

int main(int argc, char** argv)
{
    CStack<int> stack;
    stack.push(1);
    stack.push(2);
    stack.push(3);
    stack.push(4);
    stack.push(5);
    stack.push(6);
    stack.push(7);
    stack.push(8);
    stack.traverse();
    cout << stack.pop() << " " << stack.pop() << endl;
    stack.traverse();
    stack.clear();
    stack.traverse();
    return 0;
}

在这里插入图片描述

对应STL:
  • stack:

    堆栈。其原理是先进后出(FILO),其底层容器可以是任何标准的容器适配器,默认为deque双端队列

推荐阅读

C/C++专栏:https://blog.csdn.net/weixin_45068267/category_12268204.html
(内含其它数据结构及对应STL容器使用)

标签:node,CStackNode,top,NULL,C++,stack,push,数据结构,Stack
From: https://blog.csdn.net/weixin_45068267/article/details/139328907

相关文章

  • 杂数据结构选做
    杂数据结构选做持续更新ing...更新多少取决于我卷了多少似乎都是比较基础的东西,但是我数据结构太菜了,没办法╮(╯_╰)╭#9016.CodeChefMINXORSEG有两种做法,我敲的后一种第一种先不考虑范围问题,考虑现在有三个点\(u,v,w\),若它们的\(lcp\)为\(l\),那么考虑第\(l+1\)位,根据......
  • 【C++】初始化列表、隐式转换、static成员、友元与匿名对象
    文章目录1.初始化列表2.explicit关键字2.1隐式类型转换2.2explicit3.static成员3.1成员变量3.2成员函数4.友元4.1友元函数4.2友元类5.内部类6.匿名对象1.初始化列表在创建对象时,编译器通过调用构造函数,给对象中各个成员变量一个合适的初始值。classDate{publ......
  • 校园导航系统C++
    制作一个简单的大学城导航系统,根据用户指定的起点和终点,求出最短路径长度以及具体路径。项目要求:1)程序与数据相分离,地图中的所有数据都是从文件读入,而不是写在代码中2)最短路径算法不能调用函数库3)菜单界面可以循环显示,每次显示前先清屏4)输入的起点和终点若不存在,能给出相......
  • Linux C进阶 —— 与C++互相调用
      本文介绍C、C++函数互相引用的方法,以及各类目标文件(含.o目标文件、.a静态库、.so动态库)在互调使用中的详细编译链接方法。本文使用arm的交叉编译工具链作为编译和链接工具。1.C调用C++方法(asio为c++库)示例源码树:$tree..├──include│├──asio││├──......
  • c++结构体解决复数辐角问题
     结构体相关知识及运行代码(来自发发老师)/*ch10_structs.cc介绍:这里解释了结构体的使用方法。包括:(1)定义和初始化。(2)赋值。(3)结构体和数组一起使用。注意数据成员和函数成员的访问。(4)结构体和向量一起使用。(5)结构体和函数。*/#include<iostream>......
  • 数据结构学习笔记-快速排序
    快速排序的算法设计与分析问题描述:设计并分析快速排序【算法设计思想】选择基准值:从待排序数组中选择一个元素作为基准值(pivot)。在这个示例中,选择了数组中的最后一个元素作为基准值。分割数组:将数组分割为两部分,小于等于基准值的元素放在基准值的左边,大于基准值的元素放在右......
  • 【c++基础(五)】内存管理--new
    1.前言在C语言中,有四个内存管理函数:malloc,calloc,realloc和free但是使用起来他们却是非常的不方便:int*p1=(int*)malloc(sizeof(int)*n);int*p2=(int*)calloc(4,sizeof(int));int*p3=(int*)realloc(p2,sizeof(int)*10);同时这里也会出现一个问题,malloc不会进......
  • 【c++基础(四)】类和对象下--初始化列表等概念
    1.前言类和对象到这里基本已经接近尾声,本篇文章主要介绍一些与类和对象有关的相关细节,在后续使用类和对象中也有可能用的到。本章重点:本篇文章重点讲解初始化列表,友元,匿名对象和类中的static成员,以及类中的内部类的概念。 2.初始化列表 在谈论初始化列表之前就要再次......
  • 优化Python中的数据结构与算法(指南)
    ......
  • 区间和(C++)
    题目描述】给定一个全部为零的数列,规定有两种操作,一是修改某个元素,二是求区间的连续和。【输入】输入数据第一行包含两个正整数n,m(n≤100000,m≤500000) ,以下是m 行,每行有三个正整数k,a,b (k=0 或1,a,b≤n ).k=0 时表示将a 处数字加上b ,k=1 时表示询问区间[a,b......