LinkStack(链栈)
2024-09-06 23:48:59
链栈即链式栈,也就是说我们不用再考虑空间的大小,可随心所欲的进行数据的插入/删除了。和顺序栈一样,仍然要保持其stack的特性,只在一端进行插入和删除,后进先出。
(2018-02-14 代码更新)
linkstack.h:
#ifndef __LINKSTACK_H_
#define __LINKSTACK_H_ #define bool int
#define true 1
#define false 0 typedef int KeyType; typedef struct lstack
{
KeyType key;
struct lstack * top;
}Stack; Stack*CreateStack();
int IsEmpty();
bool Push();
bool Pop();
Stack*getTopNode();
KeyType getTop();
void Clear();
void Destroy(); #endif
linkstack.c:
/* linkstack.c */
#include <stdio.h>
#include <stdlib.h>
#include "linkstack.h" Stack*CreateStack(void)
{
Stack*s; s = (Stack*)malloc(sizeof(Stack));
s->top = NULL; return s;
} int IsEmpty(Stack*s)
{
return s->top == NULL;
} bool Push(Stack*s, KeyType Data)
{
Stack*p; if((p = (Stack*)malloc(sizeof(Stack))) == NULL)
return false;
p->key = Data;
p->top = s->top;
s->top = p;
return true;
} bool Pop(Stack*s)
{
Stack*p; if(IsEmpty(s))
return false;
p = s->top;
s->top = s->top->top;
free(p);
p = NULL;
return true;
} Stack*getTopNode(Stack*s)
{
return s->top;
} KeyType getTop(Stack*s)
{
return getTopNode(s)->key;
} void Clear(Stack*s)
{
while(!IsEmpty(s))
Pop(s);
} void Destroy(Stack*s)
{
if(s != NULL)
{
Clear(s);
if(s != NULL)
free(s);
s = NULL;
}
}
最新文章
- SQLAlchemy ORM之建表与查询
- HTML是什么
- verilog中符号位的扩展问题
- Sqli-labs less 30
- 使用MySQL中的EXPLAIN解释命令来检查SQL
- 引入OO开发报表后的感想
- Eclipse SVN插件账号、密码修改
- poj1308 Is It A Tree?(并查集)详解
- PHP学习笔记三十三【自定义错误处理器】
- Zabbix 中文使用手册
- 玩转Eclipse--如何使用eclipse可以更好的提高我们的工作效率
- vuex概念详解
- mybatis 中使用 in 查询
- react与fetch
- Redis、RabbitMQ、Memcached
- 那些年读过的书《Java并发编程实战》和《Java并发编程的艺术》三、任务执行框架&mdash;Executor框架小结
- Sublime Text 3(中文)添加Lua编译环境
- 一个不错的nomad raw_exec &;&; docker 运行例子(集成访问网关)
- gotop(返回顶部)
- 团队冲刺--six
热门文章
- 迭代器:遍历集合元素的操作. iterator()
- JS高级---案例:随机小方块 (贪吃蛇的食物部分)
- 分享链接在QQ内总是被多人举报怎么办,域名防红的方案
- Java中查询某个日期下所有时间段的数据
- Codeforces Round #624 (Div. 3) A. Add Odd or Subtract Even(水题)
- samba文件共享及账户映射
- python GIL锁与多cpu
- 制作PPT时的一些技巧记录
- Java进阶学习(1)之类与对象(下)
- java语法基础--动手动脑问题及课后实验问题