C/C++数据结构之用数组实现栈

概述

要在C/C++中用数组自行实现栈,我们首先需要理解栈提供的基本操作。这些操作主要包括以下5个接口。

Push:向栈中添加一个元素。

Pop:从栈中移除顶部元素,并返回该元素。

Top:查看栈顶元素但不移除它。

IsEmpty:检查栈是否为空。

Size:获取栈中元素的数量。

实现原理

如果我们用固定大小的数组来实现栈,优点是简单、快速。但这样不够灵活,容量一开始就定死了。如果数据太多就会溢出,太少又浪费内存。为了更灵活地管理内存,我们可以使用new []来动态分配数组空间,就像搭积木一样,需要多少就申请多少,甚至还可以自动扩容。

在下面栈CArrayStack的实现中,我们声明了四个成员变量,分别为:m_paData、m_nCapacity、m_nTopIndex、m_nCount。m_paData是一个动态分配的数组的地址,用来存储栈中的所有元素。m_nCapacity表示当前栈最多可以容纳多少个元素。m_nTopIndex表示当前栈顶元素的索引,也就是最后放入的那个元素的位置。m_nCount用于记录当前栈中已有的元素数量。

cpp 复制代码
class CArrayStack
{
public:
    CArrayStack();
    ~CArrayStack();

    void Push(int nValue);
    int Pop();

    int Top();
    bool IsEmpty();
    int Size();

private:
    void Resize();

private:
    int* m_paData;
    int m_nCapacity;
    int m_nTopIndex;
    int m_nCount;
};

Push操作

进行Push操作时,首先要判断当前栈是否已经满了。如果满了,则调用扩容函数Resize,将数组容量翻倍,以容纳更多元素。然后,将栈顶指针自增,以在新位置添加新的元素。最后,更新栈中元素的数量。具体如何实现,可参考下面的示例代码。

cpp 复制代码
void CArrayStack::Push(int nValue)
{
    if (m_nCount == m_nCapacity)
    {
        Resize();
    }

    m_paData[++m_nTopIndex] = nValue;
    m_nCount++;
}

Pop操作

进行Pop操作时,首先要判断当前栈是否为空。如果为空,则直接抛出异常。然后,将栈顶指针指向的元素返回,同时将栈顶指针自减。最后,更新栈中元素的数量。具体如何实现,可参考下面的示例代码。

cpp 复制代码
int CArrayStack::Pop()
{
    if (IsEmpty())
    {
        throw underflow_error("stack is empty");
    }

    int nValue = m_paData[m_nTopIndex--];
    m_nCount--;
    return nValue;
}

完整实现

Top操作、IsEmpty操作、Size操作都比较简单,这里就不再赘述了。CArrayStack类的完整实现,可参考下面的示例代码。

cpp 复制代码
#include <iostream>
#include <stdexcept>

using namespace std;

CArrayStack::CArrayStack()
{
    m_nCapacity = 2;
    m_paData = new int[m_nCapacity];
    m_nTopIndex = -1;
    m_nCount = 0;
}

CArrayStack::~CArrayStack()
{
    delete[] m_paData;
    m_paData = NULL;
}

void CArrayStack::Push(int nValue)
{
    if (m_nCount == m_nCapacity)
    {
        Resize();
    }

    m_paData[++m_nTopIndex] = nValue;
    m_nCount++;
}

void CArrayStack::Resize()
{
    int nNewCapacity = m_nCapacity * 2;
    int* pNewArray = new int[nNewCapacity];
    for (int i = 0; i < m_nCount; ++i)
    {
        pNewArray[i] = m_paData[i];
    }

    delete[] m_paData;
    m_paData = pNewArray;
    m_nCapacity = nNewCapacity;
}

int CArrayStack::Pop()
{
    if (IsEmpty())
    {
        throw underflow_error("stack is empty");
    }

    int nValue = m_paData[m_nTopIndex--];
    m_nCount--;
    return nValue;
}

int CArrayStack::Top()
{
    if (IsEmpty())
    {
        throw underflow_error("stack is empty");
    }

    return m_paData[m_nTopIndex];
}

bool CArrayStack::IsEmpty()
{
    return m_nCount == 0;
}

int CArrayStack::Size()
{
    return m_nCount;
}


int main()
{
    CArrayStack s;
    s.Push(66);
    s.Push(77);
    s.Push(88);

    cout << "Top element: " << s.Top() << endl;
    cout << "Pop: " << s.Pop() << endl;
    cout << "Pop: " << s.Pop() << endl;
    cout << "Current size: " << s.Size() << endl;
    cout << "Is empty: " << (s.IsEmpty() ? "True" : "False") << endl;
    return 0;
}
相关推荐
蒋星熠20 小时前
全栈开发实战指南:从架构设计到部署运维
运维·c++·python·系统架构·node.js·devops·c5全栈
杜子不疼.20 小时前
【C++】深入拆解二叉搜索树:从递归与非递归双视角,彻底掌握STL容器的基石
开发语言·c++
天若有情67320 小时前
从零实现轻量级C++ Web框架:SimpleHttpServer入门指南
开发语言·前端·c++·后端·mvc·web应用
mjhcsp21 小时前
C++ 三分查找:在单调与凸函数中高效定位极值的算法
开发语言·c++·算法
立志成为大牛的小牛21 小时前
数据结构——四十二、二叉排序树(王道408)
数据结构·笔记·程序人生·考研·算法
Elnaij1 天前
从C++开始的编程生活(13)——list和浅谈stack、queue
开发语言·c++
深思慎考1 天前
微服务即时通讯系统(服务端)——用户子服务实现逻辑全解析(4)
linux·c++·微服务·云原生·架构·通讯系统·大学生项目
草莓火锅1 天前
用c++使输入的数字各个位上数字反转得到一个新数
开发语言·c++·算法
j_xxx404_1 天前
C++ STL:阅读list源码|list类模拟|优化构造|优化const迭代器|优化迭代器模板|附源码
开发语言·c++
散峰而望1 天前
C/C++输入输出初级(一) (算法竞赛)
c语言·开发语言·c++·算法·github