栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

顺序栈实验代码C++

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

顺序栈实验代码C++

#include
using namespace std;
#define STACK_INIT_SIZE 100//存储空间初始分配量
#define STACKINCREMENT 10//存储空间分配增量
#define OVERFLOW -2
#define OK 1
#define ERROR -1
typedef int SElemType;
typedef int Status;
//顺序栈结构体定义
typedef struct {
	SElemType * base;//底指针
	SElemType * top;//顶指针
	int stacksize;
}SqStack;
//初始化栈
Status InitStack(SqStack &S) {
	S.base = new SElemType[STACK_INIT_SIZE];//动态分布一个空间
	if (!S.base)exit(OVERFLOW);//exit退出函数
	S.top = S.base;//顶指针与底指针相等,栈为空
	S.stacksize = STACK_INIT_SIZE;
	return OK;
}
//将元素 e 入栈
Status Push(SqStack &S, SElemType e) {
	if (S.top - S.base >= S.stacksize)//栈满
		S.base = new SElemType[STACK_INIT_SIZE + STACKINCREMENT];
	//增加内存
	if (!S.base)exit(OVERFLOW);//每次有新的内存申请都要判断
	*S.top = e;//顶指针放入元素e
	S.top++;//顶指针移动到下一个
	//*S.top ++= e;简单写法
	return OK;
}
//出栈,用 e 返回出栈元素
Status Pop(SqStack &S, SElemType &e) {
	if (S.top == S.base)//判断栈是不是为空
		return ERROR;
	e = *--S.top;
	return e;
}
//返回栈顶元素
Status GetTop(SqStack S, SElemType &e) {

	return (*--S.top);

}
//清空栈,变为空栈
void Clear(SqStack &S) {
	if(S.base)
	S.top = S.base;
	
}
//遍历栈元素 (从栈到栈顶)
void Traverse(SqStack S) {
	while (S.top - S.base > 0)
	{
		cout << *S.base << " ";
		S.base++;
	}
}
Status StackEmpty(SqStack S)//若栈S为空栈,则返回OK 否则返回ERROR
{
	if (S.top == S.base)
		return ERROR;
	else
		return OK;


}
//进制转换函数,将十进制数 dec 转化为 n 进制数,并输出转换后结果
void Convert(int dec, int n) {
	SqStack S;
	SElemType e;
	InitStack(S);
	int i = 0;
	while (dec!=0) {
		Push(S, dec%n);
		dec = dec / n;
		i++;//i是计数器,记录有几个元素入栈了
	}
	int j = 0;
	while (j> c;
		switch (c)
		{
		case 1: {
			cout << "请输入要入栈的元素";
			cin >> e;
			Push(st, e);
			
			break; }
		case 2: {
			e=Pop(st, e);
			cout <<"出栈元素是"<< e;
			break; }
		case 3: {cout << "栈顶元素是" << GetTop(st, e);
			break; }
		case 4: {Traverse(st);
			break; }
		case 5: {Clear(st);
			cout << "清空成功";
			break; }
		case 6: {
			cout << "请输入一个十进制的数和要转换的进制";
			int dec, n;
			cin >> dec >> n;
			Convert(dec, n);
			break; }
		case 7:break;
		}
	}
}

写了很多注释,方便我自己理解的,这其实是我数据结构课的实验报告

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/457507.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号