链栈即链式栈,也就是说我们不用再考虑空间的大小,可随心所欲的进行数据的插入/删除了。和顺序栈一样,仍然要保持其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;
}
}

  

最新文章

  1. SQLAlchemy ORM之建表与查询
  2. HTML是什么
  3. verilog中符号位的扩展问题
  4. Sqli-labs less 30
  5. 使用MySQL中的EXPLAIN解释命令来检查SQL
  6. 引入OO开发报表后的感想
  7. Eclipse SVN插件账号、密码修改
  8. poj1308 Is It A Tree?(并查集)详解
  9. PHP学习笔记三十三【自定义错误处理器】
  10. Zabbix 中文使用手册
  11. 玩转Eclipse--如何使用eclipse可以更好的提高我们的工作效率
  12. vuex概念详解
  13. mybatis 中使用 in 查询
  14. react与fetch
  15. Redis、RabbitMQ、Memcached
  16. 那些年读过的书《Java并发编程实战》和《Java并发编程的艺术》三、任务执行框架&mdash;Executor框架小结
  17. Sublime Text 3(中文)添加Lua编译环境
  18. 一个不错的nomad raw_exec &amp;&amp; docker 运行例子(集成访问网关)
  19. gotop(返回顶部)
  20. 团队冲刺--six

热门文章

  1. 迭代器:遍历集合元素的操作. iterator()
  2. JS高级---案例:随机小方块 (贪吃蛇的食物部分)
  3. 分享链接在QQ内总是被多人举报怎么办,域名防红的方案
  4. Java中查询某个日期下所有时间段的数据
  5. Codeforces Round #624 (Div. 3) A. Add Odd or Subtract Even(水题)
  6. samba文件共享及账户映射
  7. python GIL锁与多cpu
  8. 制作PPT时的一些技巧记录
  9. Java进阶学习(1)之类与对象(下)
  10. java语法基础--动手动脑问题及课后实验问题