目录
1.
栈的概念及结构
2.栈的实现
3.用C语言实现栈 子系统
1.栈的概念及结构
栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端
称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。
压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。
出栈:栈的删除操作叫做出栈。出数据也在栈顶。
2.栈的实现
栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些。因为数组在尾上插入数据的代价较小
3.用C语言实现栈 子系统
Stack.h
#pragma once
#include<stdio.h>
#include<assert.h>
#include<malloc.h>
#include <stdbool.h>
//结构
typedef int STDataType;
typedef struct Stack
{
//使用动态分配内存
STDataType* a;
int top; //栈顶的位置
int capacity; //容量
}ST;
//基本操作实现
void StackInit(ST* ps); //栈初始化
void StackDestory(ST* ps);//清栈
void StackPush(ST* ps, STDataType x);//插入数据 入栈
void StackPop(ST* PS); //删除数据 出栈
bool StackEmpty(ST* ps); //判断 判断栈是否为空
int StackSize(ST* ps);// 求栈元素个数
STDataType StackTop(ST* ps);//返回栈顶元素
Stack.c
#define _CRT_SECURE_NO_WARNINGS
#include"Stack.h"
//栈初始化
void StackInit(ST* ps)
{
assert(ps);
ps->a = NULL;
ps->capacity = ps->top = 0;
}
//清栈
void StackDestory(ST* ps)
{
assert(ps);
free(ps->a);
ps->a = NULL;
ps->capacity = ps->top = 0;
}
//插入数据
void StackPush(ST* ps, STDataType x)
{
assert(ps);
//栈满要扩容
if (ps->top == ps->capacity)
{
int newCapacity = ps->capacity == 0 ? 4 : ps->capacity * 2;
ST* p = (STDataType*)realloc(ps->a, newCapacity * sizeof(STDataType));
//如果申请成功 把新空间给ps->a
//开辟新空间失败 返回NULL 报错 realloc fail 结束程序
if (p != NULL)
{
ps->a = p;
}
else
{
printf("realloc fail\n");
exit(-1);
}
ps->capacity = newCapacity;
}
ps->a[ps->top] = x;
ps->top++;
}
//删除数据
void StackPop(ST* ps)
{
assert(ps);
assert(ps->top > 0);
--ps->top;
}
//检查栈空
bool StackEmpty(ST* ps)
{
assert(ps);
/*if (ps->top > 0)
{
return false;
}
else
{
return true;
}*/
//初始化正常 ps->top不可能小于0
//等于0就是空 不然就是假
return ps->top == 0;
}
//求栈顶元素
STDataType StackTop(ST* ps)
{
assert(ps);
assert(ps->top > 0);
return ps->a[ps->top - 1];
}
//检查元素个数
int StackSize(ST* ps)
{
assert(ps);
return ps->top;
}
Test.c
#define _CRT_SECURE_NO_WARNINGS
#include"Stack.h"
int main()
{
ST ps;
//初始化
StackInit(&ps);
//入栈
StackPush(&ps, 4);
StackPush(&ps, 2);
StackPush(&ps, 5);
StackPush(&ps, 6);
StackPush(&ps, 7);
StackPush(&ps, 8);
StackPush(&ps, 9);
StackPush(&ps, 10);
while (!StackEmpty(&ps)) //!main的意思是 当main为假或者为0的时候才会成立 并执行
{
printf("%d\n", StackTop(&ps));
StackPop(&ps);
}
StackDestory(&ps);
return 0;
}