文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言中怎么实现链栈

2023-06-15 03:48

关注

这篇文章将为大家详细讲解有关C语言中怎么实现链栈,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

链栈图解

C语言中怎么实现链栈

链栈的常规操作

LinkStack  InitLinkStack();// 初始化链栈int     StackEmpty();// 判断链栈空int     StackLength();// 求链栈长(链栈元素个数)int     Push();// 入栈 压栈ElemType  Pop();// 出栈 弹栈void   DestroyStack();// 销毁链栈

定义链栈结构体

#include "stdio.h"#include "malloc.h"#define TRUE  1#define FALSE 0typedef int ElemType;// 链栈存储元素的数据类型typedef struct Node{ElemType data;// 栈结点数据域struct Node *next;// 栈结点指针域}*LinkStack, Node;

初始化链栈

// 初始化链栈(带头结点的链栈)LinkStack InitLinkStack(){LinkStack s = (LinkStack)malloc(sizeof(struct Node));s -> next = NULL;return s;}

链栈判空

int StackEmpty(LinkStack s){if(s == NULL){return FALSE;}return s -> next == NULL;}

因为是链式存储结构,无需链栈判满。

计算链栈的长度

int StackLength(LinkStack s){LinkStack p;int len = 0;if(StackEmpty(s)){return FALSE;}p = s -> next;// 带头结点的链栈要先移动一下while(p != NULL){len ++;p = p -> next;}return len;}

链栈入栈(Push)

int Push(LinkStack s, ElemType data){// 分配入栈结点Node *new_node = (Node *)malloc(sizeof(struct Node));if (new_node == NULL) return FALSE;// 结点分配失败// 跟单链表一样使用头插法new_node -> data = data;new_node -> next = s -> next;s -> next = new_node;return TRUE;}

链栈出栈(Pop)

ElemType Pop(LinkStack s){LinkStack top;ElemType data;// 判栈空if(StackEmpty(s)){return FALSE;}top = s -> next;// 访问栈顶结点data = top -> data;// 取出栈顶元素s -> next = top -> next;free(top);// 释放栈顶空间return data;}

链栈各操作测试

// 程序主入口int main(int argc, char const *argv[]){LinkStack s = InitLinkStack();printf("StackEmpty():%d\n", StackEmpty(s));printf("StackLength():%d\n\n", StackLength(s));// 入栈元素ElemType datas[] = {1, 3, 5, 7, 9};// 动态计算入栈元素个数int len = sizeof(datas) / sizeof(datas[0]);// for循环依次入栈printf("Push():");for(int i = 0; i < len; i++){printf("%d\t", datas[i]);Push(s, datas[i]);}printf("\nStackEmpty():%d\n", StackEmpty(s));printf("StackLength():%d\n\n", StackLength(s));// 出栈 弹栈printf("Pop(): ");while(!StackEmpty(s)){printf("%d\t", Pop(s));}printf("\nStackEmpty():%d\n", StackEmpty(s));printf("StackLength():%d\n\n", StackLength(s));return 0;}

结果如下:

StackEmpty():1StackLength():0Push():1        3       5       7       9StackEmpty():0StackLength():5Pop(): 9        7       5       3       1StackEmpty():1StackLength():0

C语言是什么

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