首页 > 其他 > 详细

链式栈的基本操作与实现

时间:2015-05-17 13:47:50      阅读:279      评论:0      收藏:0      [点我收藏+]

1:头文件:SqStack.h
#include<stdio.h>
#include<stdlib.h>
#define ElemType int
#define STACK_SIZE 100
#define ADD_SIZE 10

typedef struct SqStack
{
	ElemType *base;
	ElemType *top;
	int stacksize;
}SqStack;

bool Isempty(SqStack *s); //栈是否为空
bool IsFull(SqStack *s);  //判栈是否已满
void InitStack(SqStack *s);  //初始化栈
void PushStack(SqStack *s,ElemType x);  //入栈
void PopStack(SqStack *s,ElemType *x);  //出栈
void ShowStack(SqStack *s); //显示栈
void GetTop(SqStack *s,ElemType *x);//获取栈顶数据
void ClearStack(SqStack *s);  //清理栈
void DestoryStack(SqStack *s); //摧毁栈
void Show();     //显示菜单
2:功能实现文件SqStack.cpp
#include"SqStack.h"

void Show()
{
	printf("***************************************\n");
	printf("* [1]:入栈            [2]:出栈        *\n");
	printf("* [3]:显示栈          [4]:获取栈顶数据*\n");
	printf("* [5]:摧毁栈          [6]:清理栈      *\n");
	printf("* [0]:结束程序                        *\n");
	printf("***************************************\n");
	printf("请选择:");
}

void InitStack(SqStack *s)
{
	s->base=(ElemType*)malloc(STACK_SIZE*sizeof(ElemType));
	if(s->base==NULL)
	{
		printf("开辟空间失败\n");
		return ;
	}
	s->top=s->base;
	s->stacksize=STACK_SIZE;
}

bool IsFull(SqStack *s)
{
	return s->top-s->base>=s->stacksize;
}

bool Isempty(SqStack *s)
{
	return s->base==s->top;
}
void PushStack(SqStack *s,ElemType x)
{
	if(IsFull(s))
	{
		s->base=(ElemType*)realloc(s->base,(s->stacksize+ADD_SIZE)*sizeof(ElemType));
		
		if(s->base==NULL)
		{
			printf("增加空间失败\n");
			return;
		}
		s->top=s->base+s->stacksize;
		s->stacksize+=ADD_SIZE;
	}
	*s->top=x;
	s->top++;
}

void PopStack(SqStack *s,ElemType *x)
{
	if(Isempty(s))
	{
		printf("栈为空,不能出栈\n");
		return;
	}
	s->top--;
	*x=*s->top;	
}


void GetTop(SqStack *s,ElemType *x)
{
	if(Isempty(s))
	{
		printf("栈为空,不能获取栈数据\n");
		return;
	}
	*x=*(s->top-1);
}

void ClearStack(SqStack *s)
{
	s->base=s->top=NULL;
	s->stacksize=0;
}
void DestoryStack(SqStack *s)
{
	free(s->base);
	ClearStack(s);
}
void ShowStack(SqStack *s)
{
	ElemType *top=s->top;
	while(top!=s->base)
	{
		top--;
		printf("%d ",*top);
		
	}
	printf("\n");
}
3:主文件main.cpp
#include"SqStack.h"

void main()
{
	SqStack s;
	ElemType x;
	int pos=1;

	InitStack(&s);
	while(pos)
	{
		Show();
		scanf("%d",&pos);
		switch(pos)
		{
		case 1:
			printf("输入数据,以-1结束:");
			while(scanf("%d",&x),x!=-1)
			{
				PushStack(&s,x);
			}
			break;
		case 2:
			PopStack(&s,&x);
	        printf("出栈数据:%d\n",x);
			break;
		case 3:
			ShowStack(&s);
			break;
		case 4:
			GetTop(&s,&x);
			printf("获取栈顶数据:%d\n",x);
			break;
		case 5:
			DestoryStack(&s);
			printf("栈已被摧毁\n");
			break;
		case 6:
			ClearStack(&s);
			printf("栈已被清理\n");
			break;
		default:
			break;
		case 0:	return;
		}
	}	
}
技术分享

链式栈的基本操作与实现

原文:http://blog.csdn.net/zhou753099943/article/details/45787911

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!