news 2026/6/23 5:28:36

数据结构-栈(核心代码)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构-栈(核心代码)

顺式结构

#define _CRT_SECURE_NO_WARNINGS 1 //栈的顺式结构 #include<stdio.h> #define MAXSIZE 100 typedef int Elemtype; //定义栈 typedef struct stack { Elemtype data[MAXSIZE]; int top; }Stack; //初始化栈 void initstack(Stack* S) { S->top = -1; } //判断栈是否为空 int isempty(Stack* S) { if (S->top == -1) { printf("空的\n"); return 1; } else { return 0; } } //进栈/压栈 int pushStack(Stack* S,Elemtype e) { if (S->top >= MAXSIZE - 1) { printf("满了\n"); return 0; } S->top++; S->data[S->top] = e; return 1; } //出栈 int pop(Stack* S, Elemtype* e) { if (S->top >= MAXSIZE - 1) { printf("满了\n"); return 0; } *e = S->data[S->top]; S->top--; return 1; } //获取栈顶元素 int get_top(Stack* S, Elemtype* e) { if (S->top == -1) { printf("空的\n"); return 0; } *e = S->data[S->top]; return 1; } int main() { Stack S; initstack(&S); pushStack(&S,10); pushStack(&S,20); pushStack(&S,30); Elemtype e; pop(&S, &e); printf("%d\n", e); get_top(&S, &e); printf("%d\n", e); return 0; } //动态内存分配定义和初始化栈 #include<stdlib.h> #define MAXSIZE 100 typedef int Elemtype; typedef struct stack { Elemtype* data; int top; }Stack; Stack* initstack(Stack* S) { Stack* S = (Stack*)malloc(sizeof(Stack)); S->data = (Elemtype*)malloc(sizeof(Elemtype)*MAXSIZE); S->top = -1; return S; }

链式结构

#define _CRT_SECURE_NO_WARNINGS 1 //栈的链式结构 #include<stdio.h> #include<stdlib.h> typedef int Elemtype; #define MAXSIZE 100 //定义栈 typedef struct stack { Elemtype data; struct stack* Next;//栈顶 }Stack; //初始化栈 Stack* initstack() { Stack* S = (Stack*)malloc(sizeof(Stack)); S->data = 0; S->Next = NULL; return S; } //判断栈是否为空 int isEmpty(Stack* S) { if (S->Next == NULL) { printf("空的\n"); return 1; } else { return 0; } } //进展/压栈(相当于头插法,链式结构的栈只能头插法不能尾插法) int push(Stack* S, Elemtype e) { Stack* P = (Stack*)malloc(sizeof(Stack)); P->data = e; P->Next = S->Next; S->Next = P; return 1; } //出栈 int pop(Stack* S, Elemtype* e) { if (S->Next == NULL) { printf("空的\n"); return 0; } *e = S->Next->data; Stack* Q = S->Next; S->Next = Q->Next; free(Q); return 1; } //获取栈顶元素 int get_top(Stack* S, Elemtype* e) { if (S->Next == NULL) { printf("空的\n"); return 0; } *e = S->Next->data; return 1; } int main() { Stack* S = initstack(); isEmpty(S); push(S, 10); push(S, 20); push(S, 30); push(S, 40); Elemtype e; pop(S, &e); printf("%d\n", e); get_top(S, &e); printf("%d\n", e); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 6:34:51

哔哩下载姬:解锁B站视频离线收藏的终极方案

还在为无法随时随地观看B站精彩内容而苦恼吗&#xff1f;哔哩下载姬作为一款开源视频下载工具&#xff0c;能够轻松实现B站视频的离线收藏&#xff0c;支持从标清到8K超清的全画质下载&#xff0c;是每位B站深度用户的必备神器。 【免费下载链接】downkyi 哔哩下载姬downkyi&am…

作者头像 李华
网站建设 2026/6/23 6:24:38

关于电脑端抓包小程序的3种方法,黑客技术零基础入门到精通教程

声明&#xff1a;本号分享的安全工具、漏洞复现和项目均来源于网络&#xff0c;仅供安全研究与学习之用&#xff0c; 如用于其他用途&#xff0c;由使用者承担全部法律及连带责任&#xff0c;与工具作者和本号无关。关于电脑端对小程序进行安全测试抓包的一些方法和思路&#x…

作者头像 李华
网站建设 2026/6/10 17:10:02

AMD Nitro-E:轻量级文本到图像扩散模型家族的技术突破与性能解析

AMD Nitro-E&#xff1a;轻量级文本到图像扩散模型家族的技术突破与性能解析 【免费下载链接】Nitro-E 项目地址: https://ai.gitcode.com/hf_mirrors/amd/Nitro-E 在人工智能图像生成领域&#xff0c;高效与高质量的平衡一直是开发者追求的核心目标。AMD近期推出的Nit…

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

AI学习与职业发展:一次关于证书与能力的真实思考

在职业发展的某个阶段&#xff0c;许多职场人都会面临相似的困惑&#xff1a;在人工智能技术快速发展的背景下&#xff0c;如何通过系统性学习来增强自己的职业竞争力&#xff1f;作为从传统内容领域转向数字策略方向的从业者&#xff0c;我也曾面临选择学习路径的难题。经过近…

作者头像 李华
网站建设 2026/6/23 0:26:54

详细描述一条 SQL 在 MySQL 中的执行过程

一条 SQL 在 MySQL 中的执行&#xff0c;是一个贯穿服务层与存储引擎层的精密过程。第一阶段&#xff1a;服务层处理&#xff08;连接、解析与规划&#xff09;连接器 职责&#xff1a;管理客户端连接、身份认证与权限校验。详细过程&#xff1a;客户端通过TCP连接后&#xff0…

作者头像 李华