当前位置: 首页 > article >正文

C++详解实现Stack方法

栈简介栈本着先进后出的原则来存取数据。作为数据结构中的一种这里不多介绍相关栈。仅以此文记录C中栈的实现可帮助提升编程能力与对栈的理解。stack模拟stack是一种容器适配器专门在具有后进先出的上下文环境中其删除只能是在一端进行操作。stack是作为容器适配器被实现的容器适配器即是对特定类封装作为其底层的容器并提供一组特定的成员函数来访问其元素将特定类作为其底层的元素特定容器的尾部(即栈顶)被压入和弹出 。stack的底层原理可以是任何标椎的容器类模板或者一些特定的容器类这些容器类应该支持以下操作empty:判空操作。back:尾部元素获取。push_back尾部插入元素操作pop_back:尾部删除元素操作。模拟实现123456789101112131415161718192021222324252627282930313233templateclassT,classCon dequeTclassstack{public:stack();voidpush(constT x){_c.push_back(x);}voidpop(){_c.pop_back();}T top(){return_c.back()}constT top()const{return_c.back();}size_tsize()const{return_c.size();}boolempty()const{return_c.empty();}private:Con _c;};​示例代码直接上代码。SeqStack.h1234567891011121314151617181920212223#pragma once#define MAX_SIZE 1024#define TRUE 1#define FALSE 0typedefstructSEQSTACK {void*data[MAX_SIZE];intsize;}SeqStack;classMySeqStack{public:MySeqStack();~MySeqStack();voidinit();voidpushStack(void*data);void* getTopStack();voidpopStack();intisEmpty();intgetSizeStack();voidclearStack();private:SeqStack *m_stack;};SeqStack.cpp123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100#include SeqStack.h#include iostreamusingnamespacestd;MySeqStack::MySeqStack(){}MySeqStack::~MySeqStack(){if(m_stack ! nullptr){deletem_stack;m_stack nullptr;}}voidMySeqStack::init(){m_stack newSeqStack;if(m_stack nullptr){cout 分配内存为空 endl;}else{m_stack-size 0;for(inti 0; i m_stack-size; i){m_stack-data[i] nullptr;}}}voidMySeqStack::pushStack(void* data){if(m_stack-size MAX_SIZE){return;}if(m_stack nullptr){return;}if(data nullptr){return;}m_stack-data[m_stack-size] data;m_stack-size;}void* MySeqStack::getTopStack(){if(m_stack nullptr){returnnullptr;}if(m_stack-size 0){returnnullptr;}returnm_stack-data[m_stack-size-1];}voidMySeqStack::popStack(){if(m_stack nullptr){return;}if(m_stack-size 0){return;}m_stack-data[m_stack-size - 1] nullptr;m_stack-size--;}intMySeqStack::isEmpty(){if(m_stack nullptr){return-1;}if(m_stack-size 0){returnTRUE;}returnFALSE;}intMySeqStack::getSizeStack(){returnm_stack-size;}voidMySeqStack::clearStack(){if(m_stack nullptr){return;}for(inti 0; i m_stack-size; i){m_stack-data[i] nullptr;}m_stack-size 0;}main.cpp123456789101112131415161718192021222324252627282930313233343536373839404142434445#include iostream#include SeqStack.husingnamespacestd;typedefstructPERSON {charname[64];intage;intscore;}Person;voidtest(){MySeqStack *stack newMySeqStack;stack-init();Person p1 {hudf,3,56 };Person p2 {akso,4,67 };Person p3 {及家属的,6,88};Person p4 {口袋,7,98 };Person p5 {husdh,8,34 };stack-pushStack(p1);stack-pushStack(p2);stack-pushStack(p3);stack-pushStack(p4);stack-pushStack(p5);while(stack-getSizeStack() 0){Person *data (Person*)stack-getTopStack();cout name >开发环境vs2017控制台输出程序。运行结果到此这篇关于C详解实现Stack方法的文章就介绍到这了

相关文章:

C++详解实现Stack方法

栈简介栈本着先进后出的原则,来存取数据。作为数据结构中的一种,这里不多介绍相关栈。仅以此文记录C中栈的实现,可帮助提升编程能力与对栈的理解。stack模拟stack是一种容器适配器,专门在具有后进先出的上下文环境中,其…...

构建智能交易系统:高效掌握缠论量化实战技巧

构建智能交易系统:高效掌握缠论量化实战技巧 【免费下载链接】chan.py 开放式的缠论python实现框架,支持形态学/动力学买卖点分析计算,多级别K线联立,区间套策略,可视化绘图,多种数据接入,策略开…...

3步掌握智慧树自动学习:解放双手的课程自动化神器

3步掌握智慧树自动学习:解放双手的课程自动化神器 【免费下载链接】zhihuishu 智慧树刷课插件,自动播放下一集、1.5倍速度、无声 项目地址: https://gitcode.com/gh_mirrors/zh/zhihuishu 还在为智慧树平台繁琐的视频学习而烦恼吗?智慧…...

Windows Defender终极控制:开源工具defender-control完全指南

Windows Defender终极控制:开源工具defender-control完全指南 【免费下载链接】defender-control An open-source windows defender manager. Now you can disable windows defender permanently. 项目地址: https://gitcode.com/gh_mirrors/de/defender-control…...

跨越生态鸿沟:Windows如何优雅解码苹果的HEIC格式

跨越生态鸿沟:Windows如何优雅解码苹果的HEIC格式 【免费下载链接】windows-heic-thumbnails Enable Windows Explorer to display thumbnails for HEIC/HEIF files 项目地址: https://gitcode.com/gh_mirrors/wi/windows-heic-thumbnails 你知道吗&#xff…...

如何5分钟掌握LDDC歌词工具:面向音乐爱好者的终极歌词管理指南

如何5分钟掌握LDDC歌词工具:面向音乐爱好者的终极歌词管理指南 【免费下载链接】LDDC 简单易用的精准歌词(逐字歌词/卡拉OK歌词)下载匹配工具|A simple and user-friendly tool for downloading and matching precise lyrics (word-by-word lyrics/Karaoke lyrics) …...

思源宋体TTF:7种字重打造专业中文排版的全新体验

思源宋体TTF:7种字重打造专业中文排版的全新体验 【免费下载链接】source-han-serif-ttf Source Han Serif TTF 项目地址: https://gitcode.com/gh_mirrors/so/source-han-serif-ttf 还在为中文设计项目的字体选择头疼吗?今天我要分享一个让我工作…...

突发!Karpathy 加入 Anthropic,重回一线搞研发

①就在刚刚不久,前 OpenAI 创始团队成员 Andrej Karpathy 发推宣布加入 Anthropic。我已加入 Anthropic。我认为未来几年大语言模型(LLM)领域的前沿发展将极具塑造性。我非常兴奋能加入这里的团队,重新投入研发工作。我对教育事业…...

AI 编码循环验证关卡:结构背压比智能代理更优,Shen-Backpressure 来助力!

结构背压优于智能代理:用 Shen-Backpressure 为 AI 编码循环设验证关卡2026 年 5 月 18 日,一些最严重的软件漏洞往往不起眼,访问控制漏洞仍是 [OWASP 十大安全风险中的头号问题](https://owasp.org/Top10/2025/A01_2025-Broken_Access_Contr…...

RA6M3 HMI开发板SDHI接口与SD卡存储性能深度测评

1. 项目概述:从一块开发板到人机交互界面的探索最近在做一个工业现场数据监控终端的原型,核心需求是在一块屏幕上实时显示传感器数据、设备状态,并且能通过触摸屏进行简单的参数设置。选型的时候,瑞萨电子的RA6M3 HMI Board进入了…...

Windows字体美化终极指南:No!! MeiryoUI恢复你的系统字体自定义权

Windows字体美化终极指南:No!! MeiryoUI恢复你的系统字体自定义权 【免费下载链接】noMeiryoUI No!! MeiryoUI is Windows system font setting tool on Windows 8.1/10/11. 项目地址: https://gitcode.com/gh_mirrors/no/noMeiryoUI 还在为Windows系统单调的…...

告别闪烁!用STM32CubeMX快速配置PWM+DMA驱动WS2812彩灯(F4系列实测)

告别闪烁!用STM32CubeMX快速配置PWMDMA驱动WS2812彩灯(F4系列实测) 在嵌入式开发中,驱动WS2812彩灯往往需要精确的时序控制,传统软件延时方式不仅占用CPU资源,还容易因中断干扰导致灯光闪烁。本文将展示如何…...

DownKyi终极指南:B站视频下载与管理的完整专业解决方案

DownKyi终极指南:B站视频下载与管理的完整专业解决方案 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等&…...

chatgpt-web-midjourney-proxy的TypeScript类型系统:类型安全的AI应用开发

chatgpt-web-midjourney-proxy的TypeScript类型系统:类型安全的AI应用开发 在当今AI技术快速发展的时代,如何构建稳定可靠的AI应用成为开发者面临的重要挑战。chatgpt-web-midjourney-proxy项目通过精心设计的TypeScript类型系统,为开发者提供…...

终极指南:ChatGPT-Web-Midjourney-Proxy如何实现实时AI交互的WebSocket通信

终极指南:ChatGPT-Web-Midjourney-Proxy如何实现实时AI交互的WebSocket通信 ChatGPT-Web-Midjourney-Proxy是一套集成ChatGPT、Midjourney和GPTs功能的全栈UI解决方案,通过WebSocket技术实现了流畅的实时AI交互体验。本文将深入解析其WebSocket通信机制…...

跨平台AI应用开发终极指南:ChatGPT Web Midjourney Proxy移动端适配全解析

跨平台AI应用开发终极指南:ChatGPT Web Midjourney Proxy移动端适配全解析 ChatGPT Web Midjourney Proxy是一款集成ChatGPT、Midjourney和GPTs功能的一站式AI应用,本文将详细解析其移动端适配方案,帮助开发者快速掌握跨平台AI应用的开发技巧…...

chatgpt-web-midjourney-proxy的插件系统:扩展AI功能的开发指南

chatgpt-web-midjourney-proxy的插件系统:扩展AI功能的开发指南 在当今AI应用快速发展的时代,chatgpt-web-midjourney-proxy项目以其强大的插件系统脱颖而出,为开发者提供了无限扩展AI功能的可能性。这个项目不仅整合了ChatGPT、Midjourney和…...

如何快速上手Orbit:新手入门10个技巧 [特殊字符]

如何快速上手Orbit:新手入门10个技巧 🚀 【免费下载链接】orbit Experimental spaced repetition platform for exploring ideas in memory augmentation and programmable attention 项目地址: https://gitcode.com/gh_mirrors/orbit1/orbit Orb…...

Aspia代码架构解析:从基础库到完整应用的开发思路

Aspia代码架构解析:从基础库到完整应用的开发思路 【免费下载链接】aspia Remote desktop and file transfer tool. 项目地址: https://gitcode.com/gh_mirrors/as/aspia Aspia是一款功能强大的开源远程桌面和文件传输工具,支持Windows、Linux和m…...

如何选择最适合的许可证扫描工具:LicenseFinder与其他工具的全面对比分析

如何选择最适合的许可证扫描工具:LicenseFinder与其他工具的全面对比分析 【免费下载链接】LicenseFinder Find licenses for your projects dependencies. 项目地址: https://gitcode.com/gh_mirrors/li/LicenseFinder 在当今开源软件盛行的时代&#xff0c…...

终极指南:3步在电脑上免费畅玩PS4游戏的神器——shadPS4模拟器

终极指南:3步在电脑上免费畅玩PS4游戏的神器——shadPS4模拟器 【免费下载链接】shadPS4 PS4 emulator for Windows,Linux,MacOS 项目地址: https://gitcode.com/gh_mirrors/shad/shadPS4 还在为无法在电脑上体验PS4独占游戏而烦恼吗?shadPS4模拟…...

VSCodium终极指南:零监控的VS Code开源替代方案

VSCodium终极指南:零监控的VS Code开源替代方案 【免费下载链接】vscodium binary releases of VS Code without MS branding/telemetry/licensing 项目地址: https://gitcode.com/gh_mirrors/vs/vscodium VSCodium是一款基于Visual Studio Code源代码构建的…...

kagent架构深度解析:4大核心组件如何协同构建云原生AI智能体平台

kagent架构深度解析:4大核心组件如何协同构建云原生AI智能体平台 【免费下载链接】kagent Cloud Native Agentic AI | Discord: https://bit.ly/kagentdiscord 项目地址: https://gitcode.com/gh_mirrors/ka/kagent kagent是一个专为Kubernetes设计的云原生A…...

从图灵完备到意图完备:人工智能的本体论跃迁

什么是真正的智能?是能够执行任意计算任务,还是能够在世界中“存在”,感知、欲望、思考和行动?是能够给出所有正确答案,还是能够提出一个有意义的问题?是能够优化任何给定的目标,还是能够为自己…...

Azure 资源管理器编程:resourcemanager 模块的 100+ 服务集成

Azure 资源管理器编程:resourcemanager 模块的 100 服务集成 【免费下载链接】azure-sdk-for-go This repository is for active development of the Azure SDK for Go. For consumers of the SDK we recommend visiting our public developer docs at: 项目地址:…...

Fansly下载器完整指南:3分钟掌握免费离线下载技巧

Fansly下载器完整指南:3分钟掌握免费离线下载技巧 【免费下载链接】fansly-downloader Easy to use fansly.com content downloading tool. Written in python, but ships as a standalone Executable App for Windows too. Enjoy your Fansly content offline anyt…...

告别复杂命令:3步搞定M3U8视频下载的终极指南

告别复杂命令:3步搞定M3U8视频下载的终极指南 【免费下载链接】N_m3u8DL-CLI-SimpleG N_m3u8DL-CLIs simple GUI 项目地址: https://gitcode.com/gh_mirrors/nm3/N_m3u8DL-CLI-SimpleG 你是否曾经遇到过这样的困扰?在网上找到了心仪的视频教程或精…...

从零开始构建FPGA项目:ADI HDL开发实战经验分享

从零开始构建FPGA项目:ADI HDL开发实战经验分享 【免费下载链接】hdl HDL libraries and projects 项目地址: https://gitcode.com/gh_mirrors/hd/hdl ADI HDL(Analog Devices HDL)是一套功能强大的硬件描述语言库,专为FPG…...

UDEV Gothic字体测试与质量保证:确保跨平台兼容性的完整流程

UDEV Gothic字体测试与质量保证:确保跨平台兼容性的完整流程 【免费下载链接】udev-gothic UDEV Gothic は、ユニバーサルデザインフォントのBIZ UDゴシックと、 開発者向けフォントの JetBrains Mono を合成した、プログラミング向けフォントです。 项目地址: ht…...

告别B站界面混乱:3步找回经典小电视播放器

告别B站界面混乱:3步找回经典小电视播放器 【免费下载链接】Bilibili-Old 恢复旧版Bilibili页面,为了那些念旧的人。 项目地址: https://gitcode.com/gh_mirrors/bi/Bilibili-Old 你是否对B站新版界面感到无所适从?那些复杂的推荐算法…...