您的位置:首页 > 理论基础 > 数据结构算法

2015-10-12 【项目2 - 建立链栈算法库】

2015-10-12 16:54 525 查看
2015-10-12   
数据结构之自建算法库——链栈


1.问题及代码

按照“0207将算法变程序”部分建议的方法,建设自己的专业基础设施算法库。

代码:

1.头文件:

listack.h,包含定义链栈数据结构的代码、宏定义、要实现算法的函数的声明;

#ifndef LISTACK_H_INCLUDED
#define LISTACK_H_INCLUDED

typedef char ElemType;
typedef struct linknode
{
ElemType data;              //数据域
struct linknode *next;      //指针域
} LiStack;                      //链栈类型定义

void InitStack(LiStack *&s);  //初始化栈
void DestroyStack(LiStack *&s);  //销毁栈
int StackLength(LiStack *s);  //返回栈长度
bool StackEmpty(LiStack *s);  //判断栈是否为空
void Push(LiStack *&s,ElemType e);  //入栈
bool Pop(LiStack *&s,ElemType &e);  //出栈
bool GetTop(LiStack *s,ElemType &e);  //取栈顶元素
void DispStack(LiStack *s);  //输出栈中元素

#endif // LISTACK_H_INCLUDED


2.源文件:

listack.cpp,包含实现各种算法的函数的定义

#include <stdio.h>
#include <malloc.h>
#include "listack.h"

void InitStack(LiStack *&s)  //初始化栈
{
s=(LiStack *)malloc(sizeof(LiStack));
s->next=NULL;
}

void DestroyStack(LiStack *&s)  //销毁栈
{
LiStack *p=s->next;
while (p!=NULL)
{
free(s);
s=p;
p=p->next;
}
free(s);    //s指向尾结点,释放其空间
}

int StackLength(LiStack *s)  //返回栈长度
{
int i=0;
LiStack *p;
p=s->next;
while (p!=NULL)
{
i++;
p=p->next;
}
return(i);
}

bool StackEmpty(LiStack *s)  //判断栈是否为空
{
return(s->next==NULL);
}

void Push(LiStack *&s,ElemType e)  //入栈
{
LiStack *p;
p=(LiStack *)malloc(sizeof(LiStack));
p->data=e;              //新建元素e对应的节点*p
p->next=s->next;        //插入*p节点作为开始节点
s->next=p;
}

bool Pop(LiStack *&s,ElemType &e)  //出栈
{
LiStack *p;
if (s->next==NULL)      //栈空的情况
return false;
p=s->next;              //p指向开始节点
e=p->data;
s->next=p->next;        //删除*p节点
free(p);                //释放*p节点
return true;
}

bool GetTop(LiStack *s,ElemType &e)  //取栈顶元素
{
if (s->next==NULL)      //栈空的情况
return false;
e=s->next->data;
return true;
}

void DispStack(LiStack *s)  //输出栈中元素
{
LiStack *p=s->next;
while (p!=NULL)
{
printf("%c ",p->data);
p=p->next;
}
printf("\n");
}


 

2.运行结果





3.学习心得

 
链栈的作用比较强大,也比较复杂。


4.心得体会

 
多上机,自己编写代码才能真正将知识吸收,不然只能是纸上谈兵,所学甚少。


 

 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息