数据结构题型10-链栈

//参考博客:https://blog.csdn.net/weixin_37716512/article/details/104068102
#include <iostream>  //引入头文件
using namespace std;typedef int Elemtype;#define Maxsize 10
#define ERROR 0
#define OK    1typedef struct Linknode
{Elemtype data;   // 数据域struct Linknode *next;   //指针域
}Linknode,* LinkStack;void InitStack(LinkStack& L)
{L = (LinkStack)malloc(sizeof(Linknode));L->next = NULL;
}bool StackEmpty(LinkStack L)
{if (L->next == NULL)   //堆空{cout<<"栈为空"<<endl;return ERROR;}else              //不空{cout << "栈不为空" << endl;return OK;}
}bool Push(LinkStack &L, Elemtype e)
{Linknode *s = (LinkStack)malloc(sizeof(Linknode));s->data = e;s->next = L->next;L->next = s;return OK;
}bool Pop(LinkStack& L, Elemtype &e)
{if (L->next == NULL){cout << "栈为空" << endl;return ERROR;}Linknode* p = L->next;e = p->data;L->next = p->next;cout << "出栈元素值为: " << e << endl;free(p);return OK;
}bool GetTop(LinkStack& L, Elemtype& e)
{if (L->next == NULL){cout << "栈为空" << endl;return ERROR;}e = L->next->data;cout << "栈顶元素值为: " << e << endl;return OK;
}void PrintStack(LinkStack L)
{Linknode* p= L->next;while (p != NULL){cout << "|______" << p->data << "______|" << endl;p = p->next;}
}
int main(void)
{LinkStack S = NULL;InitStack(S);StackEmpty(S);Push(S, 1);Push(S, 2);Push(S, 3);Push(S, 4);StackEmpty(S);PrintStack(S);int e = 0, x = 0;Pop(S, e);PrintStack(S);GetTop(S, x);
}

在这里插入图片描述

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

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

相关文章

9月24日,每日信息差

今天是2023年09月24日&#xff0c;以下是为您准备的12条信息差 第一、米博发布无滚布洗地机升级7系V7Pro、Q7Pro 第二、我国首个投入商业开发的大型页岩气田产气量突破600亿立方米。该气田作为我国首个投入商业开发的大型页岩气田&#xff0c;累计产气量日前已突破600亿立方米…

vue2/vue3 v-if与v-show的区别 | 触发的生命周期

文章目录 v-if 和 v-show 的区别触发的生命周期普通变量组件v-if vue2/vue3行为基本一致v-show v-if 和 v-show 的区别 v-if"false"时&#xff0c;在该位置创建一个注释节点&#xff0c;用来标识元素在页面中的位置。在值发生改变的时候&#xff0c;通过diff&#x…

【Redis GEO】1、地理位置类型的基本用法

1、Redis GEO介绍 Redis GEO 主要用于存储地理位置信息&#xff0c;并对存储的信息进行操作&#xff0c;该功能在 Redis 3.2 版本新增。 Redis GEO 操作方法有&#xff1a; geoadd&#xff1a;添加地理位置的坐标。geopos&#xff1a;获取地理位置的坐标。geodist&#xff1…

adb 命令集

adb 查看app启动时间 1.清除时间 adb shell am start -S com.android.systemui/.SystemUIService2.启动应用并记录 adb shell am start -W <PACKAGE_NAME>/.<ACTIVITY_NAME>TotalTime: 491 adb 查看分辨率、dpi 分辨率 adb shell wm sizePhysical size: 1080…

DS18B20温度传感器

DS18B20简介 DS18B20 是由 DALLAS 半导体公司推出的一种的“一线总线&#xff08;单总线&#xff09;”接口的温度传感器 这种一线总线就是 三线制 SPI DS18B20的 配置寄存器&#xff1a; TM 是测试位&#xff0c;出厂设置就被设置为0&#xff0c;不需要改动&#xff0c; R1、R…

Golang开发--defer关键字

defer是Go语言中的一个关键字&#xff0c;用于延迟执行函数或方法的调用。defer语句会将其后面的函数或方法调用推迟到当前函数返回之前执行&#xff0c;无论函数是正常返回还是发生异常。 func main() {defer fmt.Println("defer 1")defer fmt.Println("defer…

企业架构LNMP学习笔记61

Nginx作为tomcat的前段反向代理&#xff1a; 在实际业务环境中&#xff0c;用户是直接通过域名访问&#xff0c;基于协议一般是http、https等。默认tomcat运行在8080端口。一般会通过前端服务器反向代理到后端的tomcat的方式&#xff0c;来实现用户可以通过域名访问tomcat的we…

微信收款码费率0.38太坑了

作为一个有多年运营经验的商家&#xff0c;我本人在申请收款功能时曾经走过了不少弯路。我找遍了市面上的知名的支付公司&#xff0c;但了解到的收款手续费率通常都在0.6左右&#xff0c;最低也只能降到0.38。这个过程吃过不少苦头。毕竟&#xff0c;收款功能是我们商家的命脉&…

AI聊天ChatGPT系统源码卡密验证开源版

ChatGPT卡密验证版源码是一个基于PHP7.4和MySQL5.6的聊天AI源码&#xff0c;它不仅支持暗黑模式、反应速度极快&#xff0c;而且充值方面采用后台生成卡密方式&#xff0c;方便快捷&#xff0c;如果您有能力将其接入在线支付&#xff0c;即可进一步拓展充值方式&#xff0c;为更…

KMeans算法全面解析与应用案例

目录 一、聚类与KMeans介绍聚类的基础概念KMeans算法的重要性 二、KMeans算法原理数据集和特征空间距离度量算法步骤 三、KMeans案例实战案例背景&#xff1a;客户细分数据集说明Python实现代码输出与解释 四、KMeans的优缺点优点计算效率高算法简单易于实现 缺点需要预设K值对…

9月22日上课内容 Docker

Docker 基本管理 docker 发展历史 https://www.cnblogs.com/rongba/articles/14782624.html Docker 概述 Docker是一个开源的应用容器引擎&#xff0c;基于go语言开发并遵循了apache2.0协议开源。 Docker是在Linux容器里运行应用的开源工具&#xff0c;是一种轻量级的“虚拟…

一、机器学习基础知识:基本概念与Python开发环境

文章目录 1、机器学习的不同类型1.1 监督学习1.2 无监督学习1.3 强化学习 2、Python开发环境2.1 Python第三方库2.2 AnacondaPycharm集成开发环境 1、机器学习的不同类型 机器学习属于人工智能的一个分支&#xff0c;专门用于对数据进行自动分析以发现相关规律&#xff0c;从而…

视频监控/视频汇聚/安防视频监控平台EasyCVR配置集群后有一台显示离线是什么原因?

开源EasyDarwin视频监控TSINGSEE青犀视频平台EasyCVR能在复杂的网络环境中&#xff0c;将分散的各类视频资源进行统一汇聚、整合、集中管理&#xff0c;在视频监控播放上&#xff0c;TSINGSEE青犀视频安防监控汇聚平台可支持1、4、9、16个画面窗口播放&#xff0c;可同时播放多…

leetcode 55. 跳跃游戏

题目链接&#xff1a;leetcode 55 1.题目 给你一个非负整数数组 nums &#xff0c;你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标&#xff0c;如果可以&#xff0c;返回 true &#xff1b;否则&#x…

芯片验证就是一次旅行

如果你国庆希望去一个你不曾去过的城市旅行&#xff0c;比如“中国苏州”。对游客来说&#xff0c;它是个蛮大的城市&#xff0c;有许多景点可以游玩&#xff0c;还有许多事情可以做。但实际上&#xff0c;即使最豪也最清闲的游客也很难看苏州的所有方方面面。同样的道理也适用…

肖sir__mysql中数据库后端无法展示

mysql中数据库后端无法展示&#xff1a; 错误现象 解决方法&#xff1a; mysql中数据库后端无法展示&#xff1a;my.cnf (5,7数据库) 在 mysql 配置文件中加入&#xff1a; sql_modeNO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 或者重启数据库

Android Kotlin 基础详解

1,基础语法 1.1 可变变量与不可变变量 可以多次赋值的变量是可变变量&#xff0c;用关键字var表示&#xff1a; var <标识符> : <类型> <初始化值> 注意&#xff0c;在kotlin中成员变量不会赋默认值&#xff0c;不像java一样&#xff0c;必须手动添加默…

Android12之容器类SortedVector、KeyedVector、Vector、VectorImpl总结(一百六十六)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…

Centos 7 访问局域网windows共享文件夹

Refer: centos7 访问windows系统的共享文件夹_centos访问windows共享_三希的博客-CSDN博客 一、在CentOS中配置CIFS网络存储服务 CIFS&#xff08;Common Internet File System&#xff09;是一种在网络上共享文件的协议&#xff0c;也称为SMB&#xff08;Server Message Blo…

rabbit start 启动和 detached 启动区别

使用 rabbitmq-server -start 命令启动 RabbitMQ 时&#xff0c;RabbitMQ 服务器将在前台运行&#xff0c;并将日志输出到终端。在这种模式下&#xff0c;如果终端关闭&#xff0c;RabbitMQ 服务器也会停止运行。&#xff08;就是管理命令窗口关闭 rabbit就会停止服务&#xff…