#include<iostream>
using namespace std;
#define OK 1
#define ERROR -1
#define OVERFLOW -2
typedef int Status;
typedef struct SNode{
int data;
struct SNode *next;
}SNode,*LinkStack;
Status InitStack(LinkStack &S){
S = NULL;
return OK;
}
Status Push(LinkStack &S,int m){
SNode *p=new SNode;
if(!p)
return OVERFLOW;
p->data=m;
p->next=S;
S=p;
return OK;
}
Status Pop(LinkStack &S,int &m){
SNode *p;
if(!S)
return ERROR;
m=S->data;
p=S;
S=S->next;
delete p;
return OK;
}
bool StackEmpty(LinkStack &S){
if(!S)
return true;
return false;
}
void conversion(int num){
LinkStack S;
int num_fir,num_sec;
InitStack(S);
cout<<"输入你想要转换的进制数:"<<endl;
cin>>num_fir;
if(num_fir!=16){
while(num){
Push(S,num%num_fir);
num/=num_fir;
}
cout<<"该数字转换成"<<num_fir<<"进制后为"<<endl;
while(!StackEmpty(S)){
Pop(S,num_sec);
cout<<num_sec;
}
}
else{
while(num){
Push(S,num%num_fir);
num/=num_fir;
}
cout<<"该数字转换成16进制后为"<<endl;
while(!StackEmpty(S)){
Pop(S,num_sec);
if(num_sec>9)
printf("%c",num_sec+55);
cout<<num_sec;
}
}
cout<<endl;
}
int main(){
int n;
while(true){
cout<<"请输入你所要转换的十进制数字:"<<endl;
cout<<"如果你想要退出,请输入-1:"<<endl;
cin>>n;
if(n==-1)
break;
conversion(n);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理