C语言数据结构-栈的实现-初始化、销毁、长度、取栈顶元素、查找、入栈、出栈、显示操作
1、数据结构-栈的实现-C语言
#define MAXSIZE 100
//栈的存储结构
typedef struct
{
int* base; //栈底指针
int* top; //栈顶指针
int stacksize; //最大容量
} SqStack;
//栈初始化---1
void InitStack(SqStack* S);
//栈的销毁---2
void DestroyStack(SqStack* S);
//栈的清空---3
void ClearStack(SqStack* S);
//判断栈是否为空---4
void StackEmpty(SqStack S);
//栈的长度---5
int StackLength(SqStack S);
//取栈顶元素---6
void GetTop(SqStack S);
//入栈操作---7
void Push(SqStack* S, int value);
//出栈操作---8
void Pop(SqStack* S,int* value);
//依次访问栈元素---9
void StackTraverse(SqStack 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(SqStack* S)
{
S->base = (SqStack*) malloc(MAXSIZE*sizeof(SqStack));
if(!S->base)
{
printf("分配失败.\n");
return;
}
S->top = S->base; //初始时候相等
S->stacksize = MAXSIZE; //设置最大容量
}
void DestroyStack(SqStack* S)
{
free(S->base); //释放基地址
S->top = NULL;
S->base = NULL;
}
void ClearStack(SqStack* S)
{
S->top = S->base;
}
void StackEmpty(SqStack S)
{
if(S.top == S.base)
printf("此栈为空栈。\n");
else
printf("此栈不为空栈。\n");
}
int StackLength(SqStack S)
{
return S.top - S.base;
}
void GetTop(SqStack S)
{
if(S.top == S.base)
{
printf("此栈为空。\n");
return;
}
printf("此栈顶元素为%d。\n",*(S.top-1));
}
void Push(SqStack* S, int value)
{
if(S->top-S->base == MAXSIZE)
{
printf("栈中元素已满,不能再继续添加.\n");
return;
}
*(S->top) = value;
S->top++;
printf("-入栈成功\n");
}
void Pop(SqStack* S,int* value)
{
if(S->top == S->base)
{
printf("栈中无元素,不能再进行出栈操作.\n");
return;
}
*value = *((S->top)-1);
S->top--;
printf("出栈成功\n");
}
void StackTraverse(SqStack S)
{
if(S.base == S.top){
printf("此栈为空。\n");
return;
}
int* start = S.base;
int num = 1;
while(start != S.top)
{
printf("元素%d的值为:%d\n",num,*start);
num++;
start++;
}
}
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语言 //链式栈的链式结构 typedef struct StackNode { int data; struct StackNode *next; } StackNod ...
- 【转】【数据结构】【有n个元素依次进栈,则出栈序列有多少种】
卡特兰数 大神解释:https://blog.csdn.net/akenseren/article/details/82149145 权侵删 原题 有一个容量足够大的栈,n个元素以一定的顺序 ...
- 剑指Offer20 栈的压入弹出序列是否正确
/************************************************************************* > File Name: 20_IsPopO ...
- C语言数据结构——第三章 栈和队列
三.栈和队列 栈和队列是两种重要的线性结构.从数据结构的角度来看,栈和队列也是线性表,它的特殊性在于栈和队列的基本操作是线性表操作的子集,它们的操作相对于线性表来说是受到限制的,因此,可以称其为限定性 ...
- php 栈、 出栈、入栈
最近在面试的时候被问到栈,回来做个总结,希望对大家有帮助 栈是线性表的一种,他的特点是后入先出,可以这么理解,栈就像一个存东西的盒子,先放进去的在最底层,后放进去的在上层,因为上层的东西把底层的东西压 ...
- 【NOJ2024】入栈序列和出栈序列
入栈序列和出栈序列 时间限制(普通/Java):1000MS/3000MS 运行内存限制:65536KByte 总提交:293 测试通过:68 比赛描述 给出入栈序列 ...
- n个元素进栈,共有多少种出栈顺序?
1.基于栈的问题分析 我们把n个元素的出栈个数的记为f(n), 那么对于1,2,3, 我们很容易得出: f(1) = 1 / ...
随机推荐
- Profile配置
Profile是Spring用来针对不同环境对不同的配置提供支持的,全局Profile配置使用application-{profile}.properties application.properti ...
- 第十四章 Spring MVC的工作机制与设计模式(待续)
Spring MVC的总体设计 Control设计 Model设计 View设计 框架设计的思考 设计模式解析之模版模式
- 问题:C#控制台 停留;结果:c#控制台如何延时显示
Thread.Sleep(毫秒数);//比如Thread.Sleep(2000)即为延时2秒需using System.Threading; 随笔5 - C#控制台窗口的显示与隐藏 1. 定义一个Co ...
- SpringMVC + AJAX 实现多文件异步上传
转自:https://www.jianshu.com/p/f3987f0f471f 今天,我就这个问题来写一篇如何用 SpringMVC + AJAX 实现的多文件异步上传功能.基本的代码还是沿用上篇 ...
- c:if标签数据回显判断是否选中
<form action="/brand/list.do" method="post" style="padding-top:5px;" ...
- 推荐一款GIF录制工具
LICEcap 是一款屏幕录制工具,支持导出 GIF 动画图片格式,轻量级.使用简单,录制过程中可以随意改变录屏范围 下载 http://www.cockos.com/licecap/
- xcode 编译报错“Cannot create __weak reference in file using manual reference counting”解决办法<转>
http://blog.csdn.net/ouq68/article/details/51003876 解决方法: Please set ‘Weak References in Manual Reta ...
- Django的serializers使用
Serializer 在这里通过一个验证用户身份的例子说明rest_framework中serializer.Serializer的使用. 编写serializer Serializer的使用不需要依 ...
- transient关键字的理解
谈到这个transient这个关键字,我们应该会立马想到序列化这个过程:什么是序列化?什么又是反序列化呢?序列化就是将对象转化内成二进制,而反序列化就是就二进制文件转换成对象的过程.一旦变量使用了tr ...
- array_unique() 函数移除数组中的重复的值
array_unique() 函数移除数组中的重复的值,并返回结果数组. 当几个数组元素的值相等时,只保留第一个元素,其他的元素被删除. 返回的数组中键名不变.