C++ 链栈实现10进制转换为2、8、16进制(详细)

代码实现

        (程序中已详细注释,这里不再重复说明,有疑惑可留意哦)

//导入头文件
#include<iostream>
#include<stdio.h>
#include<malloc.h>
using namespace std;//声明命名空间

//链栈
typedef struct stacknode{
	int data;//数据域
	struct stacknode *next;//指针域
}stacknode,*LinkStack;


//初始化栈,创建一个空栈 
void initLinkStack(LinkStack &L){
	L=NULL;//空链站 
} 

//判断栈是否为空
int emptyLinkStack(LinkStack L){
	if(L==NULL){
		return 0;
	}else{
		return 1;
	}
}

//入栈 
void pushLinkStack(LinkStack &L,int e){
	LinkStack p;
	p=(LinkStack)malloc(sizeof(stacknode));

	p->data=e;
	p->next=L;
	L=p;
}

//出栈 
void popLinkStack(LinkStack &L,int &e){	
	LinkStack p;
	p=L;
	e=L->data;//取出栈顶元素给e
	L=L->next;
	delete(p);
}

//十进制转2、8、16进制,采用除基倒取余法
void numberConversionL(int oNumber,int cvNumber){
	LinkStack L; //创建栈 
	int x;
	initLinkStack(L); //初始化栈 
	while(oNumber){ 
		x=oNumber%cvNumber;
		pushLinkStack(L,x);//余数入栈
		oNumber=oNumber/cvNumber;
	}
	//余数出栈  
	while(emptyLinkStack(L)){   
		popLinkStack(L,x);
		switch(x){
			case 0: case 1: case 2: case 3:
			case 4: case 5: case 6: case 7:
			case 8: case 9:cout<<x; break;
			case 10:cout<<"A"; break;
			case 11:cout<<"B"; break;
			case 12:cout<<"C"; break;
			case 13:cout<<"D"; break;
			case 14:cout<<"E"; break;
			case 15:cout<<"F"; break;
		}
	} 
} 

//主函数
int main(){
	int oNumber,cvNumber;
	int oNumberL,cvNumberL;
	int choose;
	cout<<"请选择所需功能\n1.使用链栈转换\n2.退出程序"; 
	cout<<endl; //换行 
	cin>>choose;
	while(choose!=2){
		switch(choose){
			case 1:{
				cout<<"请输入要转换的十进制数:"<<endl;
				cin>>oNumberL;
				cout<<"请输入要转换至的进制,仅限输入2、8以及16:"<<endl;
				cin>>cvNumberL;
				numberConversionL(oNumberL,cvNumberL);
				break;
			}
			default:
				cout<<"\n!!!您的选择不正确,请重新选择!!!\n";
		}
		cout<<endl; //换行 
		cout<<"请选择所需功能\n1.使用链栈转换\n2.退出程序"; 
		cout<<endl; //换行 
		cin>>choose;	
	}
    return 0;
} 

运行结果

 

写在最后:

        链栈、顺序栈实现进制转换原理相同,区别在于顺序栈、链栈的自身结构不同,如果想进一步了解顺序栈转换,请看文章:

“C++-顺序栈实现10进制转换为2、8、16进制(详细)”(点击跳转)

  • 5
    点赞
  • 74
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
下面是用链栈实现八进制转换十进制的代码实现,具体注释在代码中: ```c++ #include <iostream> #include <cmath> using namespace std; // 定义链栈结构体 struct Node { int data; Node* next; }; // 初始化链栈 void InitStack(Node*& S) { S = new Node; S->next = NULL; } // 判断链栈是否为空 bool StackEmpty(Node* S) { return S->next == NULL; } // 入 void Push(Node*& S, int x) { Node* p = new Node; p->data = x; p->next = S->next; S->next = p; } // 出 bool Pop(Node*& S, int& x) { if (StackEmpty(S)) { return false; } Node* p = S->next; x = p->data; S->next = p->next; delete p; return true; } // 读顶元素 bool GetTop(Node* S, int& x) { if (StackEmpty(S)) { return false; } x = S->next->data; return true; } // 八进制转换十进制 int OctToDec(char s[]) { Node* S = NULL; InitStack(S); int i = 0; while (s[i] != '\0') { Push(S, s[i] - '0'); // 将字符转换为数字并入 i++; } int dec = 0; int n = 0; int x; while (!StackEmpty(S)) { Pop(S, x); dec += x * pow(8, n); // 按位计算 n++; } return dec; } int main() { char s[100]; cout << "请输入一个八进制数:"; cin >> s; int dec = OctToDec(s); cout << "转换十进制为:" << dec << endl; return 0; } ``` 这里使用了链栈实现,具体的实现过程如下: 1. 从字符串的最后一位开始遍历,将每一位的数字转换为整数,并入。 2. 然后按照的后进先出的顺序,将每一位数字取出,并按照位数计算十进制值。 3. 最后得到的十进制值即为所求。 这里使用了 pow 函数来计算 $8^n$,需要在头文件中添加 math.h。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

等日出看彩虹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值