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

栈(C语言)

目录1. 栈的定义2. 代码实现1. 栈的定义栈属于线性表具有后进先出的特点存储结构类似羽毛球桶可以依次取出最后放入栈中的数据。实现栈一般采用数组 / 链表实现但是推荐程度数组 单链表 双链表。因为存取在栈顶实现因此中间元素不需要提供直接访问的功能单链表在双链表的基础上减少了指针占用的内存而数组这种顺序表结构更是比链表减少了插入数据的代价无需遍历至尾部。2. 代码实现//stack.h文件#pragma once typedef int STDataType; typedef struct Stack { STDataType* a; //指向动态数组的指针 int top; //动态数组中最后一个有效元素的下一位 int capacity; //动态数组的总容量 }ST; //栈的初始化和销毁 void STInit(ST* pst); void STDestroy(ST* pst); //入栈和出栈 void STPush(ST* pst, STDataType x); void STPop(ST* pst); //查询栈顶元素 STDataType STTop(ST* pst); //判空 bool STEmpty(ST* pst); //查询数据个数 int STSize(ST* pst);//stack.c文件#includestdio.h #includestdlib.h #includeassert.h #includestdbool.h #include stack.h //栈的初始化 void STInit(ST* pst) { assert(pst); pst-a NULL; pst-top 0; //指向数组末尾有效元素的下一位 pst-capacity 0; } //销毁 void STDestroy(ST* pst) { assert(pst); free(pst-a); pst-a NULL; pst-top pst-capacity 0; } //入栈 void STPush(ST* pst, STDataType x) { assert(pst); //需要扩容的情况 if(pst-top pst-capacity) { int newcapacity pst-capacity 0 ? 4 : 2*pst-capacity; STDataType* tmp (STDataType*)realloc(pst-a, sizeof(STDataType) * newcapacity); if(tmp NULL) { perror(realloc fail); exit(1); } pst-a tmp; pst-capacity newcapacity; } pst-a[pst-top] x; pst-top; } //出栈 void STPop(ST* pst) { assert(pst pst-top ! 0); pst-top--; } //查询栈顶元素 STDataType STTop(ST* pst) { assert(pst pst-top0); return pst-a[pst-top-1]; } //判空 bool STEmpty(ST* pst) { assert(pst); return pst-top 0; } //查询数据个数 int STSize(ST* pst) { assert(pst); return pst-top; }

相关文章:

栈(C语言)

目录 1. 栈的定义 2. 代码实现 1. 栈的定义 栈属于线性表,具有后进先出的特点,存储结构类似羽毛球桶,可以依次取出最后放入栈中的数据。实现:栈一般采用数组 / 链表实现,但是推荐程度:数组 > 单链表 …...

突破文档获取限制:kill-doc开源工具全方位解析

突破文档获取限制:kill-doc开源工具全方位解析 【免费下载链接】kill-doc 看到经常有小伙伴们需要下载一些免费文档,但是相关网站浏览体验不好各种广告,各种登录验证,需要很多步骤才能下载文档,该脚本就是为了解决您的…...

Phi-4-mini-reasoning多场景落地:K12教育智能批改、竞赛培训、教师备课助手

Phi-4-mini-reasoning多场景落地:K12教育智能批改、竞赛培训、教师备课助手 1. 模型介绍 Phi-4-mini-reasoning是一款3.8B参数的轻量级开源模型,专为数学推理、逻辑推导和多步解题等强逻辑任务设计。这款模型由微软Azure AI Foundry开发,主…...

GLM-4.1V-9B-Base效果展示:低质量压缩图(微信发送后)识别鲁棒性

GLM-4.1V-9B-Base效果展示:低质量压缩图(微信发送后)识别鲁棒性 1. 模型介绍 GLM-4.1V-9B-Base是智谱开源的视觉多模态理解模型,专门针对图像内容识别、场景描述、目标问答和中文视觉理解任务进行了优化。这个9B参数的模型在保持…...

OpenClaw自动化写作流:Phi-3-mini-128k-instruct生成技术文章+校对手册

OpenClaw自动化写作流:Phi-3-mini-128k-instruct生成技术文章校对手册 1. 为什么需要自动化写作流 上周我连续写了三篇技术文章后,突然意识到一个严重问题——每次从资料收集到最终排版,至少要消耗4小时。其中真正用于核心内容创作的时间不…...

hadoop+Spark+django基于Spark的影视作品排行榜数据分析和可视化

前言   本研究基于 Spark 框架,构建了一套与可视化系统,旨在为影视行业相关方提供有力支持。研究结合了网络爬虫、Spark 框架、Vue 和 Echarts 等技术,并采用文献研究法展开。 在数据采集阶段,使用 Python 爬虫从多个数据源获取…...

说说事务的传播级别?

面试 事务传播级别是 Spring 为了解决事务方法相互调用时事务如何传递的问题。默认传播级别是 REQUIRED,表示有事务就加入,没有事务就新建。...

深圳SEO公司为什么要定期优化网站

深圳SEO公司为什么要定期优化网站 在当今数字化时代,拥有一个优秀的网站已经不再足以满足企业的需求。随着互联网市场的竞争日益激烈,深圳SEO公司认识到定期优化网站的重要性,并将其作为持续提升网站流量和业务发展的核心策略之一。为什么深…...

清华大学重磅突破:让AI汽车真正听懂你说话,想去哪就去哪!

这项由清华大学计算机科学与技术系和GigaAI公司联合开展的研究于2026年3月26日发表在计算机视觉顶级会议论文中,论文编号为arXiv:2603.25741v1。有兴趣深入了解技术细节的读者可以通过该编号查询完整论文内容。汽车能像人类司机一样理解复杂的语言指令,并…...

SMUDebugTool:深度控制AMD Ryzen硬件参数的系统调试解决方案

SMUDebugTool:深度控制AMD Ryzen硬件参数的系统调试解决方案 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: http…...

QQ音乐加密格式解密完全指南:从原理到实践的全方位解决方案

QQ音乐加密格式解密完全指南:从原理到实践的全方位解决方案 【免费下载链接】qmcdump 一个简单的QQ音乐解码(qmcflac/qmc0/qmc3 转 flac/mp3),仅为个人学习参考用。 项目地址: https://gitcode.com/gh_mirrors/qm/qmcdump …...

2.4 Java的基础概念(数据类型)

一、什么是数据类型?在 Java 中,数据类型决定了三件事:存什么:变量能存储的数据种类(是整数、小数还是文字?)。占多大:在内存中占用多少空间(字节数)。怎么算…...

开源阅读鸿蒙版完整指南:打造你的专属数字图书馆

开源阅读鸿蒙版完整指南:打造你的专属数字图书馆 【免费下载链接】legado-Harmony 开源阅读鸿蒙版仓库 项目地址: https://gitcode.com/gh_mirrors/le/legado-Harmony 开源阅读鸿蒙版是一款专为鸿蒙系统用户设计的免费开源电子书阅读器,它彻底改变…...

如何快速配置Zotero插件:终极管理解决方案与插件市场指南

如何快速配置Zotero插件:终极管理解决方案与插件市场指南 【免费下载链接】zotero-addons Zotero Add-on Market | Zotero插件市场 | Browsing, installing, and reviewing plugins within Zotero 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-addons …...

Claude Code 常用技巧:这几个操作让我开发效率翻倍

Claude Code 常用技巧:这几个操作让我开发效率翻倍 说实话,用 Claude Code 差不多也有小半年了,从一开始"就这?"的怀疑,到现在每天开工第一件事就是把它招呼进来,中间踩了不少坑,也真…...

MouseOverShapeBox

MouseOverShapeBox MouseOverShapeBox 源码详解 - 鼠标悬停高亮标注框 这是一个增强版图像标注控件,当鼠标移动到形状上时,会高亮显示该形状。类似于图片标注工具中鼠标悬停时边框变色的效果。📄 文件头部(版权信息) /…...

Pixel Mind Decoder 版本管理与协作:Git工作流在AI项目中的应用

Pixel Mind Decoder 版本管理与协作:Git工作流在AI项目中的应用 1. 为什么AI项目需要版本管理 在开发Pixel Mind Decoder这样的情绪分析系统时,我们会频繁修改代码、调整Prompt模板、更新模型参数。如果没有版本管理,很容易陷入混乱&#x…...

从零上手!用 Python+OpenCV 实现 LBPH 人脸识别,小白也能跑通

一、写在前面:人脸识别到底是什么?你有没有好奇过,手机的人脸解锁、门禁的刷脸开门,到底是怎么认出你的?其实核心逻辑很简单:先 “记住” 人脸:把你的多张照片喂给算法,让它学习你的…...

FLUX.1-dev像素艺术生成实战:像素幻梦在RPG地图设计中的落地应用

FLUX.1-dev像素艺术生成实战:像素幻梦在RPG地图设计中的落地应用 1. 像素艺术生成新纪元 在独立游戏开发领域,像素艺术始终保持着独特的魅力。传统像素画创作需要艺术家逐格绘制,耗时耗力。而基于FLUX.1-dev模型的像素幻梦(Pixel Dream Wor…...

无障碍技术实践:OpenClaw+Phi-3-vision-128k-instruct构建语音图文助手

无障碍技术实践:OpenClawPhi-3-vision-128k-instruct构建语音图文助手 1. 项目背景与动机 去年夏天,我在一次志愿者活动中遇到几位视障开发者。他们提到日常工作中最大的障碍不是编程本身,而是无法快速获取图像信息和处理文档内容。这让我开…...

终极指南:如何无需Steam客户端轻松下载创意工坊模组

终极指南:如何无需Steam客户端轻松下载创意工坊模组 【免费下载链接】WorkshopDL WorkshopDL - The Best Steam Workshop Downloader 项目地址: https://gitcode.com/gh_mirrors/wo/WorkshopDL 你是否曾因Steam客户端无法访问创意工坊而烦恼?或者…...

P4084 [USACO17DEC] Barn Painting G 题解

题目描述Farmer John 有一个大农场,农场上有 N 个谷仓(1≤N≤105),其中一些已经涂色,另一些尚未涂色。Farmer John 想要为这些剩余的谷仓涂色,使得所有谷仓都被涂色,但他只有三种可用的油漆颜色…...

Claude颠覆AI编程

🚀 Claude 4 正式发布!Anthropic 这次真的要颠覆 AI 编程了 今天,AI 领域迎来核弹级更新——Anthropic 正式发布 Claude 4 系列模型!免费可用、7 小时自主编程,开发者直呼"生产力革命来了"! 一、…...

[特殊字符] Python 装饰器实战学习知识点梳理文档(从错题到全对版)

📚 Python 装饰器实战学习知识点梳理文档(从错题到全对版) 一、核心基础概念 ✨(装饰器的“地基”) 1. 变量作用域(避坑前提)全局变量:函数外面定义,全程序都能使用局部变…...

如何高效管理百度网盘文件:自动化批量转存与分享的完整指南

如何高效管理百度网盘文件:自动化批量转存与分享的完整指南 【免费下载链接】BaiduPanFilesTransfers 百度网盘批量转存、分享和检测工具 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduPanFilesTransfers 在数字资源日益丰富的今天,百度网盘…...

N_m3u8DL-CLI-SimpleG:跨平台M3U8视频下载工具全场景应用指南

N_m3u8DL-CLI-SimpleG:跨平台M3U8视频下载工具全场景应用指南 【免费下载链接】N_m3u8DL-CLI-SimpleG N_m3u8DL-CLIs simple GUI 项目地址: https://gitcode.com/gh_mirrors/nm3/N_m3u8DL-CLI-SimpleG 一、场景定位:用户能力与需求匹配模型 三级…...

后端实战案例:企业级框架设计与优化实践

一、前言在 2026 年的软件开发中,Java 已经成为每一位工程师必须掌握的技能。无论是构建高性能后端服务、开发响应式前端界面,还是维护生产级服务器集群,这项技术都在其中扮演着关键角色。很多开发者在入门阶段会遇到一个普遍问题&#xff1a…...

基于NSGA-II多目标遗传优化算法的考虑风光火储+需求响应+P2G多能源系统多目标优化调度研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

OpenCore Legacy Patcher技术揭秘:老设备升级macOS的创新方案与实战指南

OpenCore Legacy Patcher技术揭秘:老设备升级macOS的创新方案与实战指南 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 在苹果生态系统中&#x…...

Windows Defender Remover完整指南:如何彻底移除Windows安全组件

Windows Defender Remover完整指南:如何彻底移除Windows安全组件 【免费下载链接】windows-defender-remover A tool which is uses to remove Windows Defender in Windows 8.x, Windows 10 (every version) and Windows 11. 项目地址: https://gitcode.com/gh_m…...