这次的数据结构是一种特殊的线性表:栈(Stack)

栈的特点是后入先出(LIFO),可见的只有栈顶的一个元素。

栈在程序中的地位非常重要,其中最重要的应用就是函数的调用。每次函数调用时都会创建该函数的一个“活动记录”( Activation Record ,或称作“帧”( Frame ))压入运行时堆栈中,用于保存函数的参数,返回值,返回指令地址,返回活动记录地址,局部变量等内容。当然,在高级语言中我们不需要手动完成这一工作,学习汇编语言时会体会到其真正过程。

下面给出笔者对于堆栈的两种实现。首先是顺序(数组)存储实现:

// Stack.h

#include <stdio.h>
#include <stdlib.h> struct StackRecord;
typedef struct StackRecord *Stack; int IsEmpty(Stack S);
int IsFull(Stack S);
Stack CreateStack(int MaxElements);
void DisposeStack(Stack S);
void MakeEmpty(Stack S);
void Push(ElementType X, Stack S);
ElementType Top(Stack S);
void Pop(Stack S);
ElementType TopAndPop(Stack S);

  

// Stack.c

#include "Stack.h"

struct StackRecord{
int Capacity;
int TopOfStack;
ElementType *Array;
}; int IsEmpty(Stack S)
{
return S->TopOfStack == -1;
} int IsFull(Stack S)
{
return S->TopOfStack == S->Capacity - 1;
} Stack CreateStack(int MaxElements)
{
Stack ret;
if((ret = (Stack)malloc(sizeof(struct StackRecord))) != NULL)
{
ret->TopOfStack = -1;
ret->Capacity = MaxElements;
if((ret->Array = (ElementType*)malloc(MaxElements * sizeof(ElementType))) != NULL)
return ret;
free(ret);
}
printf("Error! Out of memory! \n");
return NULL;
} void DisposeStack(Stack S)
{
if(S)
{
free(S->Array);
free(S);
}
} void MakeEmpty(Stack S)
{
S->TopOfStack = -1;
} void Push(ElementType X, Stack S)
{
if(IsFull(S))
{
printf("Error! The stack is full! \n");
return;
}
(S->Array)[++(S->TopOfStack)] = X;
} ElementType Top(Stack S)
{
if(IsEmpty(S))
{
printf("Error! The stack is empty! \n");
return 0;
}
return (S->Array)[(S->TopOfStack)];
} void Pop(Stack S)
{
if(IsEmpty(S))
{
printf("Error! The stack is empty! \n");
return;
}
S->TopOfStack -= 1;
} ElementType TopAndPop(Stack S)
{
if(IsEmpty(S))
{
printf("Error! The stack is empty! \n");
return 0;
}
return (S->Array)[(S->TopOfStack)--];
}

  

接下来是链式存储实现:

// Stack.h

#include <stdio.h>
#include <stdlib.h> struct _Node;
typedef struct _Node Node;
typedef Node *PtrToNode;
typedef PtrToNode Stack; int IsEmpty(Stack S);
Stack CreateStack();
void DisposeStack(Stack S);
void MakeEmpty(Stack S);
void Push(ElementType X, Stack S);
ElementType Top(Stack S);
void Pop(Stack S);

  

// Stack.c

#include "Stack.h"

struct _Node
{
ElementType Element;
struct _Node *Next;
}; void print(Stack S)
{
for (PtrToNode p = S->Next; p; p = p->Next)
{
printf("%d ", p->Element);
}
printf("\n");
} int main()
{
Stack s = CreateStack();
print(s);
Pop(s);
printf("%d", Top(s));
Push(2, s);
Push(3, s);
Push(5, s);
print(s);
Pop(s);
print(s);
MakeEmpty(s);
print(s);
DisposeStack(s);
getchar();
getchar();
} int IsEmpty(Stack S)
{
return S->Next == NULL;
} Stack CreateStack()
{
Stack ret;
if ((ret = (Stack)malloc(sizeof(Node))) != NULL)
{
ret->Next = NULL;
return ret;
}
printf("Error! Out of memory! \n");
return 0;
} void DisposeStack(Stack S)
{
PtrToNode p = S;
while (S != NULL)
{
S = S->Next;
free(p);
p = S;
}
} void MakeEmpty(Stack S)
{
if (S == NULL)
{
printf("Error! It's not a Stack!\n");
return;
}
while (!IsEmpty(S))
Pop(S);
} void Push(ElementType X, Stack S)
{
PtrToNode t;
if ((t = (PtrToNode)malloc(sizeof(Node))) != NULL)
{
t->Element = X;
t->Next = S->Next;
S->Next = t;
return;
}
printf("Error! Out of memory! \n");
} ElementType Top(Stack S)
{
if (S->Next == NULL)
{
printf("Error! The stack is empty! \n");
return 0;
}
return S->Next->Element;
} void Pop(Stack S)
{
PtrToNode p = S->Next;
if (p == NULL)
{
printf("Error! The stack is empty! \n");
return;
}
S->Next = p->Next;
free(p);
}

 以上就是堆栈的两种实现。由于较为简单,不再给出测试样例。

《数据结构与算法分析——C语言描述》ADT实现(NO.01) : 栈(Stack)的更多相关文章

  1. 《数据结构与算法分析——C语言描述》ADT实现(NO.00) : 链表(Linked-List)

    开始学习数据结构,使用的教材是机械工业出版社的<数据结构与算法分析——C语言描述>,计划将书中的ADT用C语言实现一遍,记录于此.下面是第一个最简单的结构——链表. 链表(Linked-L ...

  2. 数据结构与算法分析——C语言描述 第三章的单链表

    数据结构与算法分析--C语言描述 第三章的单链表 很基础的东西.走一遍流程.有人说学编程最简单最笨的方法就是把书上的代码敲一遍.这个我是头文件是照抄的..c源文件自己实现. list.h typede ...

  3. 最小正子序列(序列之和最小,同时满足和值要最小)(数据结构与算法分析——C语言描述第二章习题2.12第二问)

    #include "stdio.h" #include "stdlib.h" #define random(x) (rand()%x) void creat_a ...

  4. C语言学习书籍推荐《数据结构与算法分析:C语言描述(原书第2版)》下载

    维斯 (作者), 冯舜玺 (译者) <数据结构与算法分析:C语言描述(原书第2版)>内容简介:书中详细介绍了当前流行的论题和新的变化,讨论了算法设计技巧,并在研究算法的性能.效率以及对运行 ...

  5. 《数据结构与算法分析-Java语言描述》 分享下载

    书籍信息 书名:<数据结构与算法分析-Java语言描述> 原作名:Data Structures and Algorithm Analysis in Java 作者: 韦斯 (Mark A ...

  6. 读书笔记:《数据结构与算法分析Java语言描述》

    目录 第 3 章 表.栈和队列 3.2 表 ADT 3.2.1 表的简单数组实现 3.2.2 简单链表 3.3 Java Collections API 中的表 3.3.1 Collection 接口 ...

  7. 《数据结构与算法分析——C语言描述》ADT实现(NO.03) : 二叉搜索树/二叉查找树(Binary Search Tree)

    二叉搜索树(Binary Search Tree),又名二叉查找树.二叉排序树,是一种简单的二叉树.它的特点是每一个结点的左(右)子树各结点的元素一定小于(大于)该结点的元素.将该树用于查找时,由于二 ...

  8. 《数据结构与算法分析——C语言描述》ADT实现(NO.05) : 散列(Hash)

    散列(Hash)是一种以常数复杂度实现查找功能的数据结构.它将一个关键词Key,通过某种映射(哈希函数)转化成索引值直接定位到相应位置. 实现散列有两个关键,一是哈希函数的选择,二是冲突的处理. 对于 ...

  9. 《数据结构与算法分析——C语言描述》ADT实现(NO.04) : AVL树(AVL-Tree)

    上次我们已经实现了普通的二叉查找树.利用二叉查找树,可以用O(logN)高度的树状结构存储和查找数据,提高了存储和查找的效率. 然而,考虑一种极端情形:依次插入1,2,3,4,5,6,7,8,9九个元 ...

随机推荐

  1. JAVA工具包_BeanUtils

    简介 大多数的java开发者通常在创建Java类的时候都会遵循JavaBean的命名模式,对类的属性生成getters方法和setters方法.通过调用相应的getXxx和setXxx方法,直接访问这 ...

  2. [转]NuGet学习笔记(1) 初识NuGet及快速安装使用

    关于NuGet园子里已经有不少介绍及使用经验,本文仅作为自己研究学习NuGet一个记录. 初次认识NuGet是在去年把项目升级为MVC3的时候,当时看到工具菜单多一项Library Package M ...

  3. LoadRunner例子:检查点为参数的一个例子

    LoadRunner例子:检查点为参数的一个例子 检查点是LoadRunner的一个功能,用来验证业务功能的正确性.如果检查的内容是变化的,脚本该如何写呢? 问题提出:LoadRunner订票网站例子 ...

  4. Vim操作 -- 按列

    1, 拷贝行 Y y 拷贝当前光标字符 如果需要拷贝整个单词,可以用 ye,e表示跳到词尾 2, 粘贴 P(大写) 粘贴到光标前 p(小写)粘贴到光标后 3, 进入快操作模式 ctrl+q 4, 用 ...

  5. 即将开源 | 2亿用户背后的Flutter应用框架Fish Redux

    背景 在闲鱼深度使用 Flutter 开发过程中,我们遇到了业务代码耦合严重,代码可维护性糟糕,如入泥泞.对于闲鱼这样的负责业务场景,我们需要一个统一的应用框架来摆脱当下的开发困境,而这也是 Flut ...

  6. Java可变参数与Collections工具类使用了解

    今天发现jdk1.5后增加了个可变参数,以前还一直不晓得 public static void main(String[] args) { System.out.println(getNum(1,2, ...

  7. 3、变量+运算符+Scanner

    1.变量 1>开辟内存空间 int num ; 2>赋值 num = 10; 3>使用 num 1*long 类型的特殊 long num = 12L 2*float类型特殊 flo ...

  8. System.Web.Mvc.ViewResultBase.cs

    ylbtech-System.Web.Mvc.ViewResultBase.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, Pub ...

  9. IDEA本地SBT项目上传到SVN

    需求 将本地创建的一个项目上到SVN 网上很多从SVN下载到idea,提交.更新.删除等操作. 但是少有从本地上传一个项目到svn管理的案例 本文参考https://blog.csdn.net/cao ...

  10. Python学习day45-数据库(总结)

    figure:last-child { margin-bottom: 0.5rem; } #write ol, #write ul { position: relative; } img { max- ...