#include<stdio.h>
#include<math.h>
#define STACK_INIT_SIZE 100
#define STACK_INCREMENT 10
using namespace std;
typedef struct Stack //结构体定义
{
int *elem; //数据域
int top; //顺序栈栈顶
int stacksize; //顺序栈当前长度
}Stack;
//函数声明部分
void Error(char *s); //错误处理函数
void Init_Stack(Stack & l);//顺序栈的初始化
void Destroy_Stack(Stack & l); //销毁顺序栈
void Clear_Stack(Stack & l); //清空顺序栈
void Push_Stack(Stack &L, int e); //压栈操作函数
void Pop_Stack(Stack &L, int e); //出栈操作函数
void Increment_Stack(Stack & l); //增加顺序栈空间函数
void Conversion_Stack(Stack &l); //进制转换函数
//函数实现部分
void Error(char *s)
{
cout << s << endl;
exit(1);
}
void Init_Stack(Stack &l)
{
l.elem = new int[STACK_INIT_SIZE];
if (!l.elem)
Error("内存分配失败!");
l.top = -1;
l.stacksize = STACK_INIT_SIZE;
}
void Destroy_Stack(Stack &l)
{
delete[] l.elem;
l.top = -1;
l.stacksize = 0;
cout << "
c语言:顺序栈的应用-进制转换
最新推荐文章于 2023-11-26 12:53:14 发布