链式栈的实现及其应用

目录

一、链式栈结构模型

二、链式栈的实现

2.1创建

2.2压栈

2.3出栈

2.4判断栈是否为空

2.5查看栈顶

2.6释放栈

三、应用


        链式栈实际上就是基于链表压栈和弹栈可分别看作头插和头删链表尾部就是栈底头指针就是栈顶指针

一、链式栈结构模型

typedef int data_t;typedef struct node{data_t data;struct node *next;
}linkstack,*plinkstack;

二、链式栈的实现

typedef int data_t;typedef struct node{data_t data;struct node *next;
}linkstack,*plinkstack;plinkstack stack_create(void);                 //创建栈
int stack_push(plinkstack top, data_t value); //压栈
data_t stack_pop(plinkstack top);             //出栈
int stack_is_empty(plinkstack top);           //判断栈是否为空
data_t stack_see_top(plinkstack top);         //查看栈顶
//因为是链式栈,动态开辟,所以不用判断栈是否满
plinkstack stack_free(plinkstack top);        //释放栈

2.1创建

plinkstack stack_create(void)
{plinkstack top;//申请空间top = (plinkstack)malloc(sizeof(linkstack));if(top == NULL){printf("stack_creat:malloc space failed!\n");return NULL;}//初始化 top作为头指针top->data = 0;top->next = NULL;return top;
}

2.2压栈

int stack_push(plinkstack top, data_t value)
{plinkstack new;//参数检查if(top == NULL){printf("stack_push:linkstack passed is NULL!\n");return -1;}//申请空间+初始化new = (plinkstack)malloc(sizeof(linkstack));if(new == NULL){printf("stack_push:malloc space failed!\n");return -1;}new->data = value;//压栈new->next = top->next;top->next = new;return 1;
}  

2.3出栈

data_t stack_pop(plinkstack top)
{plinkstack delete;//待出栈的结点data_t value;//参数检查if(top == NULL){printf("stack_pop:linkstack passed is NULL!\n");return -1;}//更新指向delete = top->next;//栈顶指针指向的结点先出栈top->next = delete->next;//栈顶指针指向出栈的下一个//保存出栈的数据value = delete->data;//释放结点空间free(delete);delete = NULL;return value;
} 

2.4判断栈是否为空

int stack_is_empty(plinkstack top)
{//参数检查if(top == NULL){printf("stack_is_empty:linkstack passed is NULL!\n");return -1;}   //判断栈顶指针指向的空间是否为空即可return (top->next == NULL? 1 : 0);
}

2.5查看栈顶

data_t stack_see_top(plinkstack top) 
{//参数检查if(top == NULL){printf("stack_see_top:linkstack passed is NULL!\n");return -1;}return (top->next->data);
}

2.6释放栈

plinkstack stack_free(plinkstack top) 
{plinkstack WaitaToFree;//参数检查if(top == NULL){printf("stack_free:linkstack passed is NULL!\n");return NULL;}//遍历释放即可while(top != NULL){WaitaToFree = top;top = top->next;free(WaitaToFree);}return NULL; //返回给主程序中的指针 避免野指针    
}

三、应用

#include <stdio.h>
#include "linkstack.h"int main(void)
{plinkstack s;s = stack_create();if(s == NULL){return -1;}stack_push(s,10);stack_push(s,20);stack_push(s,30);stack_push(s,40);stack_push(s,50);stack_push(s,60);while(!stack_is_empty(s)){printf("pop:%d\n",stack_pop(s));}s = stack_free(s);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/489275.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

视频监控汇聚平台方案设计:Liveweb视频智能监管系统方案技术特点与应用

随着科技的发展&#xff0c;视频监控平台在各个领域的应用越来越广泛。然而&#xff0c;当前的视频监控平台仍存在一些问题&#xff0c;如视频质量不高、监控范围有限、智能化程度不够等。这些问题不仅影响了监控效果&#xff0c;也制约了视频监控平台的发展。 为了解决这些问…

Ubuntu 20.04LTS 系统离线安装5.7.44mysql数据库

Ubuntu 20.04LTS 系统离线安装5.7.44mysql数据库 环境下载 MySQL 5.7.44 包安装标题检查服务是否启动成功遇到的问题登陆&修改密码&远程访问 环境 操作系统&#xff1a;Ubuntu 20.04.4 LTS 数据库&#xff1a;MySQL 5.7.34 内核版本&#xff1a;x86_64&#xff08;amd…

国信华源科技赋能长江蓄滞洪区水闸管护项目验收成果报道

“碧水悠悠绕古城&#xff0c;闸启长江万象新。”近日&#xff0c;由北京国信华源科技有限公司倾力打造的万里长江蓄滞洪区水闸管护项目&#xff0c;圆满通过验收&#xff0c;为这片鱼米之乡的防洪安全注入了新的科技活力。 长江之畔&#xff0c;水闸挺立&#xff0c;犹如干堤上…

Spring Boot教程之二十五: 使用 Tomcat 部署项目

Spring Boot – 使用 Tomcat 部署项目 Spring Boot 是一个基于微服务的框架&#xff0c;在其中创建可用于生产的应用程序只需很少的时间。Spring Boot 建立在 Spring 之上&#xff0c;包含 Spring 的所有功能。如今&#xff0c;它正成为开发人员的最爱&#xff0c;因为它是一个…

【论文阅读】PRIS: Practical robust invertible network for image steganography

内容简介 论文标题&#xff1a;PRIS: Practical robust invertible network for image steganography 作者&#xff1a;Hang Yang, Yitian Xu∗, Xuhua Liu∗, Xiaodong Ma∗ 发表时间&#xff1a;2024年4月11日 Engineering Applications of Artificial Intelligence 关键…

游戏引擎学习第42天

仓库: https://gitee.com/mrxiao_com/2d_game 简介 目前我们正在研究的内容是如何构建一个基本的游戏引擎。我们将深入了解游戏开发的每一个环节&#xff0c;从最基础的技术实现到高级的游戏编程。 角色移动代码 我们主要讨论的是角色的移动代码。我一直希望能够使用一些基…

wine的使用方法

wine版本 所有分支&#xff0c;新的主要版本&#xff1a; wine-x.0 All branches, release candidates:各分支、候选版本&#xff1a; wine-x.0-rcn Stable branch updates: 稳定分支更新&#xff1a; wine-x.0.z Development branch updates: wine-x.y wine *.exe “更改目…

Comparator.comparing 排序注意

1. 对数字型字符串排序 List<String> values new ArrayList<>();values.add("10");values.add("6");values.add("20");values.add("30");values.add("50");//方法1 &#xff08;正确的排序方法&#xff09;//倒…

springboot3整合javafx解决bean注入问题

springboot整合javafx时候&#xff0c;很多问题就在于controller没有被spring容器管理&#xff0c;无法注入bean&#xff0c;在这里提供一套自己的解决思路 执行逻辑 这里仅仅提供一个演示&#xff0c;我点击按钮之后&#xff0c;从service层返回一个文本并显示 项目结构 创…

【Linux】Nginx一个域名https一个地址配置多个项目【项目实战】

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;CSDN博客专家   &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01…

SQL中的函数介绍

大多数SQL实现支持以下类型 文本函数&#xff1a;用于处理文本字符串&#xff08;如删除或填充值&#xff0c;转换值为大写或小写&#xff09;。数值函数&#xff1a;用于在数值数据上进行算术操作&#xff08;如返回绝对值&#xff0c;进行代数运算&#xff09;。日期和时间函…

AI与大数据的深度结合:驱动决策的革命性力量

引言&#xff1a;数字时代的决策挑战 在这个信息爆炸的数字时代&#xff0c;数据早已渗透到我们生活的方方面面。全球每天产生的数据量呈指数级增长&#xff0c;无论是用户的消费行为、设备的运行状态&#xff0c;还是社会热点的实时动态&#xff0c;这些信息的规模和复杂性前所…

说下JVM中一次完整的GC流程?

大家好&#xff0c;我是锋哥。今天分享关于【说下JVM中一次完整的GC流程&#xff1f;】面试题。希望对大家有帮助&#xff1b; 说下JVM中一次完整的GC流程&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在JVM中&#xff0c;垃圾回收&#xff08;GC&am…

Leetcode 每日一题9.回文数

&#x1f308;&#x1f308;&#x1f308;今天给大家分享的是:回文数的解法 目录 ​编辑 问题描述 输入输出格式 示例 约束条件 进阶挑战 解决方案 问题分析 过题图片 字符串转换法 数学方法 算法解释 题目链接 结论 问题描述 给定一个整数 x&#xff0c;我们需要…

得物App奢侈品鉴别能力再获A级资质认证

11月20日&#xff0c;在中国出入境检验检疫协会举办的“2024高端消费品检验鉴定与市场可持续发展大会”上传出消息&#xff0c;得物App因“先鉴别、后发货”保障正品的突出表现以及较高的消费者认可度&#xff0c;被中国海关科学技术研究中心授予“奢侈品鉴别&#xff08;箱包类…

word表格里面的文字首行有空格删除不掉怎么办

1、问题 这里首行的文字一直有空格&#xff0c;删除不掉&#xff0c;且用段落调整首行缩进也一直没用&#xff1b; 改成无&#xff0c;然后一直没有用&#xff1b; 2、改进方法 用这个清除一个表格的格式后&#xff0c;后面所有表格的格式都会更新&#xff1b;再重新按照段落…

CNCF云原生生态版图-项目和产品综合分析

CNCF云原生生态版图-项目和产品综合分析 CNCF云原生生态版图-项目和产品综合分析整体统计分析中国研发人员贡献项目和产品其中&#xff0c;纳入 CNCF 管理的开源项目 链接 CNCF云原生生态版图-项目和产品综合分析 整体统计分析 在对云原生技术选型时&#xff0c;优先选择经过 …

Unity3D下采集camera场景并推送RTMP服务实现毫秒级延迟直播

技术背景 好多开发者&#xff0c;希望我们能够分享下如何实现Unity下的camera场景采集并推送rtmp服务&#xff0c;然后低延迟播放出来。简单来说&#xff0c;在Unity 中实现采集 Camera 场景并推送RTMP的话&#xff0c;先是获取 Camera 场景数据&#xff0c;通过创建 RenderTex…

SEC_ASA 第一天作业

拓扑&#xff1a; 实验需求&#xff1a; 注意&#xff1a;在开始作业之前必须先读“前言”&#xff0c;以免踩坑&#xff01;&#xff01;&#xff01;&#xff08;☞敢点我试试&#xff09; 按照拓扑图配置VLAN连接。 注意&#xff1a;ASA防火墙的 Gi0/1口需要起子接口&#x…

【电子元器件】电感基础知识

本文章是笔者整理的备忘笔记。希望在帮助自己温习避免遗忘的同时&#xff0c;也能帮助其他需要参考的朋友。如有谬误&#xff0c;欢迎大家进行指正。 一、 电感的基本工作原理 1. 电感的基本工作原理如下&#xff1a; &#xff08;1&#xff09; 当线圈中有电流通过时&#…