news 2026/6/23 18:05:19

C++数据结构:stack实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C++数据结构:stack实现

栈的实现

  • 前言
    栈是一种基础且高效的数据结构,遵循先进后出的原则。其核心操作在于压栈弹栈,分别用于在栈顶添加元素和移除栈顶元素。栈在计算机科学中广泛应用,例如在函数调用栈,表达式求值,括号匹配等场景中均发挥关键作用。本实现将详细展示栈的基本操作及其内部逻辑,通过代码与理论结合的方式,帮助读者深入理解其工作机制。

以下代码是实现stack的类,包括size(目前长度),data(指针),total(总长度)
resize(扩容函数)等。

template<typenameT>classstack{private:intsize;T*data;inttotal;voidresize();public:stack():data(newT[10]),size(0),total(10){}~stack();voidpush(T value);Tpop();Ttop()const;intgetsize()const;};

  • resize函数

对于扩容函数resize(),我们先把新的总长度变成原来的总长度的二倍。
然后申请新的空间,新的空间大小用newtotal。
然后把原来的数组的元素存到新的数组里面,然后删除原来的数组的内容,把新的newdata赋值给原来的data,这样data就指向了新的数组的首元素,此处是把指向新数组首地址的指针newdata赋值给了data,让data指向新数组的首地址。

template<typenameT>voidstack<T>::resize(){intnewTotal=total*2;T*newdata=newT[newTotal];for(inti=0;i<size;++i){newdata[i]=data[i];}delete[]data;data=newdata;total=newTotal;}

  • 析构实现
    析构函数的写法没有多余的代码,就是删除掉就好了
template<typenameT>stack<T>::~stack(){delete[]data;}

  • push函数实现
    在函数的开始先判断一下size(当前的数组的元素个数size和数组的总空间total是否相等),如果相等,那么就进入resize()函数,进行扩容,扩容后,data[size] = value,此时size = 10,然后size++,变成11.
template<typenameT>voidstack<T>::push(T value){if(size==total){resize();}data[size++]=value;}

  • pop函数实现
    进入函数先判断size(当前数组中的元素个数)是否为0,如果为0,则弹出异常提示stack是空的,否则返回size自减之后作为下标的data数据
template<typenameT>Tstack<T>::pop(){if(size==0){throwstd::underflow_error("stack is empty");}returndata[--size];}

  • top函数实现
    对于top函数我们只需要返回栈顶元素就可以了,所以我们要加一个const来保护数据。
    进入函数判断size元素个数是否为0,如果为0,则弹出异常。
    否则返回数组的元素个数减一作为下标的data数据,因为数组下标从0开始,所以10个元素的最后一个元素的下标为10 - 1 = 9;
template<typenameT>Tstack<T>::top()const{if(size==0){throwunderflow_error("stack is empty");}returndata[size-1];}

  • getsize函数实现
    对于这个函数没什么可说的,我们直接返回size,并且不要忘记加上const来保护数据。
template<typenameT>intstack<T>::getsize()const{returnsize;}

  • 总结
    以上就是stack的实现,如果你还没有搞懂指针和数组的概念和联系,可以移步我的主页,找到《另一个角度看指针》,相信会对你来说会有帮助。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/17 9:07:46

开源存储新变局:MinIO步入维护期后的五大替代方案深度解析

近日&#xff0c;开源对象存储领域发生重要变化&#xff1a;MinIO官方正式宣布其开源版本进入“维护模式”。这一变化意味着该项目将不再增加新功能&#xff0c;仅提供有限的安全更新和关键Bug修复&#xff0c;同时积极引导用户转向其商业产品MinIO AIStor&#xff08;起价约9.…

作者头像 李华
网站建设 2026/6/23 3:41:12

DAY 35 官方文档的阅读

一、官方文档的检索方式 二、官方文档的阅读和使用 三、类的关注点 1.类实例化所需的参数 实例化类&#xff08;类名()&#xff09;的本质是调用类的构造逻辑&#xff0c;核心参数由__init__方法定义&#xff08;极少数场景需关注__new__&#xff0c;但__new__参数通常与__…

作者头像 李华
网站建设 2026/6/23 11:17:06

condition参数

condition参数condition是什么为什么需要condition参数condition参数的重载方法设计condition的典型使用场景与示例condition是什么 condition 是 MyBatis-Plus 核心组件 Wrapper 体系中所有条件构建方法的可选布尔型入参&#xff0c;也是实现条件动态生效的核心控制开关&…

作者头像 李华
网站建设 2026/6/22 14:27:07

基于微信小程序的德育实践活动管理小程序设计与实现

前言 &#x1f31e;博主介绍&#xff1a;✌CSDN特邀作者、全栈领域优质创作者、10年IT从业经验、码云/掘金/知乎/B站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战&#xff0c;以及程序定制化开发、文档编写、答疑辅导等。✌…

作者头像 李华
网站建设 2026/6/23 17:43:34

基于SpringBoot+Vue的护理知识在线咨询系统设计与实现

前言 &#x1f31e;博主介绍&#xff1a;✌CSDN特邀作者、全栈领域优质创作者、10年IT从业经验、码云/掘金/知乎/B站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战&#xff0c;以及程序定制化开发、文档编写、答疑辅导等。✌…

作者头像 李华
网站建设 2026/6/23 10:00:05

基于Python+Django的社区警务信息管理系统设计与实现

前言 &#x1f31e;博主介绍&#xff1a;✌CSDN特邀作者、全栈领域优质创作者、10年IT从业经验、码云/掘金/知乎/B站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战&#xff0c;以及程序定制化开发、文档编写、答疑辅导等。✌…

作者头像 李华