下面是部分代码
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAXSIZE 100
int exitflag = 1;
typedef int status;
//typedef struct SElemType;
typedef struct StackNode
{
int data;
struct StackNode *next;
}StackNode,*LinkStack;
status Initstack(LinkStack &S);//初始化链栈
status Pushstack(LinkStack &S,int n);//入栈
status Popstack(LinkStack &S);//出栈
status EmptyStack(LinkStack S);//判断栈是否为空
void Conversion(LinkStack &S,int n,int m);//数制转换函数
void PrintMenu();
void Menu(int choice);
void Quit();
//主函数
int main()
{
int m,n;
int choice;
LinkStack S;
//Initstack(S); //初始化链栈
do
{
PrintMenu();
scanf("%d", &choice);
Menu(choice);
} while (exitflag); //实现菜单功能
return 0;
}
//初始化函数
status Initstack(LinkStack &S)
{S=NULL;
return 1;
}
//入栈函数
status Pushstack(LinkStack &S,int n)
{
int i;
LinkStack p;
p=new StackNode;
p->data=n;
p->next=S;
S=p;
return 1;
}
//出栈函数
status Popstack(LinkStack &S)
{LinkStack p;
if(S=NULL)
return 0;
p=S;
S=S->next;
return p->data;
}
//判空函数
status EmptyStack(LinkStack S)
{
if(S=NULL)
return 1;
else
return 0;
}
//输出菜单
void PrintMenu()
{
printf("\n");
printf("进制转换\n");
printf("1.输入一个十进制数n\n");
printf("2.输入转换的进制m\n");
printf("3.进制转换\n");
printf("4.继续或退出(y/n)\n");
printf("请选择1-4:");
}
//菜单内容
void Menu(int choice)
{
switch (choice) {
case 1:
int m,n;
printf("请输入十进制数n:");
scanf("%d",&n);
break;
case 2:
printf("请输入转换的进制m:");
scanf("%d",&m);
break;
case 3:
Conversion(S ,n ,m );
break;
case 4:
Quit();
break;
default:
printf("输入错误请重新输入\n");
break;
}
}
//退出
void Quit()
{
printf("是否确认退出程序\n");
printf("继续请输入N or n\n");
char c;
getchar(); //吸收缓存区多余字符
c = getchar();
if ( c == 'y') {
exitflag = 0;
}
else {
if (c == 'n') {
exitflag = 1;