文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C++链栈的实现代码怎么写

2023-07-02 13:05

关注

这篇文章主要讲解了“C++链栈的实现代码怎么写”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++链栈的实现代码怎么写”吧!

链栈简述

链栈从概念上看是链表和栈的结合,含有栈先进后出的特性,也具有链表的动态增加节点的特性,这里相当于在链表的基础上增加只能从一端操作,且保持先进后出的特性。将头节点所在的那端看作栈顶,头节点后紧接着的节点所在的位置,即第一个存储数据的节点所在的位置为出栈入栈的位置。

示例代码

直接上代码:

LinkStack.h

#pragma oncetypedef struct LINKNODE {struct LINKNODE *pNext;}LinkNode;class LinkStack{public:LinkStack();~LinkStack();void pushLinkStack(LinkNode *data);void popLinkStack();LinkNode *getTopLinkStack();int getSizeLinkStack();void clearStack();private://这里可以不定义该类类型的指针,该类类型变量定义后只能使用单独的初始化函数初始化,//不能用构造函数,会造成循环调用构造函数的死循环中//LinkStack *m_LinkStack;LinkNode m_head;int m_size;};

LinkStack.cpp

#include "LinkStack.h"LinkStack::LinkStack(){m_size = 0;}LinkStack::~LinkStack(){}void LinkStack::pushLinkStack(LinkNode * data){if (data == nullptr){return;}data->pNext = m_head.pNext;m_head.pNext = data;m_size++;}void LinkStack::popLinkStack(){LinkNode *pDel = m_head.pNext;m_head.pNext = pDel->pNext;m_size--;}LinkNode * LinkStack::getTopLinkStack(){return m_head.pNext;}int LinkStack::getSizeLinkStack(){return m_size;}void LinkStack::clearStack(){m_head.pNext = nullptr;m_size = 0;}

main.cpp

#include <iostream>#include "LinkStack.h"using namespace std;typedef struct PERSON {LinkNode  node;char name[64];int age;}Person;void test() {LinkStack *pLinkStack = new LinkStack;Person p1, p2, p3,p4,p5;strcpy_s(p1.name,"hudh");strcpy_s(p2.name,"呼呼");strcpy_s(p3.name,"jidi");strcpy_s(p4.name, "hus");strcpy_s(p5.name, "akios");p1.age = 34;p2.age = 45;p3.age = 67;p4.age = 67;p5.age = 78;pLinkStack->pushLinkStack((LinkNode*)&p1);pLinkStack->pushLinkStack((LinkNode*)&p2);pLinkStack->pushLinkStack((LinkNode*)&p3);pLinkStack->pushLinkStack((LinkNode*)&p4);pLinkStack->pushLinkStack((LinkNode*)&p5);while (pLinkStack->getSizeLinkStack() > 0) {Person *pData = (Person*)pLinkStack->getTopLinkStack();cout << "name: " << pData->name << " age:" << pData->age << endl;pLinkStack->popLinkStack();}delete pLinkStack;pLinkStack = nullptr;} int main(){test();return 0;}// 运行程序: Ctrl + F5 或调试 >“开始执行(不调试)”菜单// 调试程序: F5 或调试 >“开始调试”菜单// 入门使用技巧: //   1. 使用解决方案资源管理器窗口添加/管理文件//   2. 使用团队资源管理器窗口连接到源代码管理//   3. 使用输出窗口查看生成输出和其他消息//   4. 使用错误列表窗口查看错误//   5. 转到“项目”>“添加新项”以创建新的代码文件,或转到“项目”>“添加现有项”以将现有代码文件添加到项目//   6. 将来,若要再次打开此项目,请转到“文件”>“打开”>“项目”并选择 .sln 文件

开发环境

vs2017 控制台输出程序。

运行结果

C++链栈的实现代码怎么写

注意

栈是连续的存储空间,故而在数量上会受到限制,而链栈打破了栈的内存空间的连续性,扩展性更强。

感谢各位的阅读,以上就是“C++链栈的实现代码怎么写”的内容了,经过本文的学习后,相信大家对C++链栈的实现代码怎么写这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯