C语言数据结构-链式栈的实现-初始化、销毁、长度、取栈顶元素、查找、入栈、出栈、显示操作
1、数据结构-链式栈的实现-C语言
//链式栈的链式结构
typedef struct StackNode
{
int data;
struct StackNode *next;
} StackNode,*LinkStack;
//链式栈初始化---1
void InitStack(LinkStack* S);
//链式栈的销毁---2
void DestroyStack(LinkStack* S);
//链式栈的清空---3
void ClearStack(LinkStack* S);
//判断链式栈是否为空---4
void StackEmpty(LinkStack S);
//链式栈的长度---5
int StackLength(LinkStack S);
//取链式栈顶元素---6
void GetTop(LinkStack S);
//入链式栈操作---7
void Push(LinkStack* S, int value);
//出链式栈操作---8
void Pop(LinkStack* S,int* value);
//依次访问链式栈元素---9
void StackTraverse(LinkStack S);
void ShowHelp();
//----------------------------------------------------
void ShowHelp()
{
printf("1---初始化链式栈\n");
printf("2---销毁链式栈\n");
printf("3---清空链式栈\n");
printf("4---判断链式栈是否为空\n");
printf("5---链式栈的长度\n");
printf("6---取链式栈顶元素\n");
printf("7---入链式栈操作\n");
printf("8---出链式栈操作\n");
printf("9---依次访问链式栈元素\n");
}
void InitStack(LinkStack* S)
{
//栈顶指针指向空,刚开始只有一个指针,不和单链表一样有头结点。不需要分配空间。
*S = NULL;
}
void DestroyStack(LinkStack* S)
{
LinkStack q;
while(*S){
q = *S;
*S = (*S)->next;
free(q);
}
}
void ClearStack(LinkStack* S)
{
LinkStack q;
while(*S){
q = *S;
*S = (*S)->next;
free(q);
}
*S = NULL;
//和销毁差别在于,销毁后,最后又初始化了一下
}
void StackEmpty(LinkStack S)
{
if(S == NULL)
printf("此栈为空栈。\n");
else
printf("此栈不为空栈。\n");
}
int StackLength(LinkStack S)
{
int num = 0;
LinkStack q = S;
while(q){
num++;
q = q->next;
}
return num;
}
void GetTop(LinkStack S)
{
if(!S)
{
printf("此栈为空。\n");
return;
}
int num;
num = S->data;
printf("此栈顶元素为%d。\n",num);
}
void Push(LinkStack* S, int value)
{
LinkStack p = (StackNode*) malloc(sizeof(StackNode));
if(!p){
printf("分配失败\n");
return ;
}
p->data = value;
p->next = *S;
*S = p;
printf("入栈成功\n");
}
void Pop(LinkStack* S,int* value)
{
if(*S == NULL)
{
printf("栈中无元素,不能再进行出栈操作.\n");
return;
}
*value = (*S)->data;
LinkStack p = *S;
*S = (*S)->next;
free(p);
printf("出栈成功\n");
}
void StackTraverse(LinkStack S)
{
if(S == NULL){
printf("此栈为空。\n");
return;
}
LinkStack p = S;
printf("从栈顶到栈底值依次为:\n");
while(p != NULL)
{
printf("%d ",p->data);
p = p->next;
}
printf("\n");
}
C语言数据结构-链式栈的实现-初始化、销毁、长度、取栈顶元素、查找、入栈、出栈、显示操作的更多相关文章
- C语言数据结构-链式队列的实现-初始化、销毁、清空、长度、队列头元素、插入、删除、显示操作
1.数据结构-链式队列的实现-C语言 typedef struct QNode { int data; struct QNode *next; }QNode,*QueuePtr; typedef st ...
- C语言数据结构-循环队列的实现-初始化、销毁、清空、长度、队列头元素、插入、删除、显示操作
1.数据结构-循环队列的实现-C语言 #define MAXSIZE 100 //循环队列的存储结构 typedef struct { int* base; //基地址 int _front; //头 ...
- C语言数据结构-队列的实现-初始化、销毁、清空、长度、队列头元素、插入、删除、显示操作
1.数据结构-队列的实现-C语言 //队列的存储结构 #define MAXSIZE 100 typedef struct { int* base; //基地址 int _front; //头指针 i ...
- C语言数据结构-栈的实现-初始化、销毁、长度、取栈顶元素、查找、入栈、出栈、显示操作
1.数据结构-栈的实现-C语言 #define MAXSIZE 100 //栈的存储结构 typedef struct { int* base; //栈底指针 int* top; //栈顶指针 int ...
- C语言实现链栈的初始化&进栈&出栈&读取栈顶元素
/*链表实现栈的一系列操作*/ #include<stdio.h> #include<stdlib.h> #define OK 1 #define ERROR 0 typede ...
- C语言实现顺序栈的初始化&进栈&出栈&读取栈顶元素
/*顺序表实现栈的一系列操作*/ #include<stdio.h> #include<stdlib.h> #define Stack_Size 50 //设栈中元素个数为50 ...
- C语言数据结构链栈(创建、入栈、出栈、取栈顶元素、遍历链栈中的元素)
/**创建链栈*创建一个top指针代表head指针*采用链式存储结构*采用头插法创建链表*操作 创建 出栈 入栈 取栈顶元素*创建数据域的结构体*创建数据域的名称指针*使用随机函数对数据域的编号进行赋 ...
- 【转】【数据结构】【有n个元素依次进栈,则出栈序列有多少种】
卡特兰数 大神解释:https://blog.csdn.net/akenseren/article/details/82149145 权侵删 原题 有一个容量足够大的栈,n个元素以一定的顺序 ...
- C语言数据结构——第三章 栈和队列
三.栈和队列 栈和队列是两种重要的线性结构.从数据结构的角度来看,栈和队列也是线性表,它的特殊性在于栈和队列的基本操作是线性表操作的子集,它们的操作相对于线性表来说是受到限制的,因此,可以称其为限定性 ...
随机推荐
- Java-API-POI-Excel:HSSFWorkbook Documentation
ylbtech-Java-API-POI-Excel:HSSFWorkbook Documentation 1.返回顶部 1. org.apache.poi.hssf.usermodel Class ...
- ES6相关实用特性
本文总结ECMAScript6相关实用特性 目录 let和const 箭头函数 class 对象字段 模板字符串 解构赋值 函数参数扩展 迭代器for...of 模块加载 map和weakmap se ...
- C# EntityFramwork(Model First)使用要点
本文介绍EntityFramework使用方法 Entity Framework的注意点 由于安装和操作的细节讲起来很琐碎,这部分只罗列出难点,其他细节请自行查阅 安装细节 Pluralize or ...
- 第二章 深入分析Java I/O的工作机制(待续)
Java的I/O类库的基本架构 磁盘I/O工作机制 网络I/O工作机制 NIO的工作方式 I/O调优 设计模式解析之适配器模式 设计模式解析之装饰器模式 适配器模式与装饰器模式的区别
- python中匹配中文,解决不匹配,乱码等问题
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe7 in position 0: ordinal 字符串前加 ur‘str’即可;
- LNMP 1.2 Nginx编译安装
Nginx官网是:nginx.org 下载稳定版本 cd /usr/local/src wget http://nginx.org/download/nginx-1.8.0.tar.gz tar zx ...
- python爬虫--常见错误
1)socket.error: [Errno 10054] ython socket.error: [Errno 10054] 远程主机强迫关闭了一个现有的连接.因为对一个网站大量的使用urlopen ...
- android wifi框架
---恢复内容开始--- frameworks/base/services/java/com/android/server/wifi 中的ReadMe文件 WifiService: Implement ...
- 1、序列化 2、转义 3、eval 4、正则表达式 5、时间处理
1.序列化 JSON.stringify(obj) 序列化 JSON.parse(str) 反序列化 2.转义 decodeURI( ) URl中 ...
- 线段树教做人系列(1)HDU4967 Handling the Past
题意:给你n组操作,分别为压栈,出栈,询问栈顶元素.每一组操作有一个时间戳,每次询问栈顶的元素的操作询问的是在他之前出现的操作,而且时间戳小于它的情况.题目中不会出现栈为空而且出栈的情况. 例如: p ...