n进制数转m进制数的方法

进制转换在竞赛中非常常见,我们一般都知道常见进制互相转换的方法, 但是竞赛时往往会考察一些罕见的转换, 例如九进制数转十一进制数, how to do?、

首先, 我们先了解一个api, _itoa;  它可以将一个十进制数转换为任意进制

char str[100];
	_itoa(sum, str, mbjz);
	cout << str;

sum, 是一个十进制数, mbjz是目标进制, str是sum转换为目标进制之后的数, 注意: 必须是char  str[] 必须是字符数组, 不能是字符串, 疯狂报错,

ok, 说到这里大家大概也能明白如何进制转换了, 就是先将一个n进制数转换为十进制数, 再将十进制数转换为目标进制数,上代码;

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
int main (){
	int num, i = 1, sum = 0, numjz, mbjinzhi;
	cin >> num >> numjz >> mbjinzhi;
	while (num){
		int temp = num % 10;
		sum += temp * i;
		num /= 10;
		i = i * numjz;
	}
	cout << "10进制 = " << sum << endl;
	char str[100];
	_itoa (sum, str, mbjinzhi);
	cout << str;
	return 0;
} 

如果我们想将str转为int型可以用atoi(str);

 但是atoi只能处理int范围的数2, 如果str代表的整型数过大就不可以用, 所以得写一个通解

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
int main (){
	LL num, numjz, mbjz;
	cin >> num >> numjz >> mbjz;
	LL i = 1;
	LL ans = 0;
	while (num){
		int temp = num % 10;
		ans += temp * i;
		i = i * numjz;
		num /= 10;
		cout << "num = " << num << " ans = " << ans << endl;
	}
    stack<int>N;
    while (ans){
       N.push(ans % mbjz);
	   ans = ans / mbjz;	
	}
	char s[100] = {'0'};
	int m = 0;
	while (!N.empty()){
		int t = N.top();
		N.pop();
		if (t >= 10) {
			s[m ++] = t - 10 + 'A';
		}
		
		else {
			s[m ++] = t + '0';
		}
	}
	m --;
	for (int i = 0; i <= m; i ++){
		cout << s[i];
	}
	cout << endl;
	return 0;
} 

利用栈来存储,逆序输出,单独处理t >= 10的情况;

  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
这里提供一种通用的算法,可以将任意进制数转换为另一种任意进制。 1. 将原始数转换为十进制。 对于一个n进制,每一位上的字乘以n的幂次方,然后将所有结果相加,即可得到该的十进制表示。 例如,将二进制1011转换为十进制: 1 * 2^3 + 0 * 2^2 + 1 * 2^1 + 1 * 2^0 = 11 2. 将十进制数转换为目标进制。 将十进制除以目标进制,得到商和余。将余作为目标进制的一个字,将商作为新的十进制,重复以上步骤,直到商为0为止。最后将所有余按照从低位到高位的顺序排列,就得到了目标进制表示的。 例如,将十进制11转换为八进制: 11 ÷ 8 = 1 ... 3 1 ÷ 8 = 0 ... 1 所以,11的八进制表示为13。 完整的代码实现如下: ```c #include <stdio.h> char digits[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"; void reverse(char *str) { int length = 0; while (str[length] != '\0') { length++; } for (int i = 0; i < length / 2; i++) { char temp = str[i]; str[i] = str[length - i - 1]; str[length - i - 1] = temp; } } void convert(char *input, int sourceRadix, int targetRadix, char *output) { int value = 0; for (int i = 0; input[i] != '\0'; i++) { int digit = 0; if (input[i] >= '0' && input[i] <= '9') { digit = input[i] - '0'; } else if (input[i] >= 'A' && input[i] <= 'Z') { digit = input[i] - 'A' + 10; } else if (input[i] >= 'a' && input[i] <= 'z') { digit = input[i] - 'a' + 10; } value = value * sourceRadix + digit; } int index = 0; while (value > 0) { int remainder = value % targetRadix; output[index++] = digits[remainder]; value /= targetRadix; } if (index == 0) { output[index++] = '0'; } output[index] = '\0'; reverse(output); } int main() { char input[100]; printf("Enter the number to convert: "); scanf("%s", input); int sourceRadix, targetRadix; printf("Enter the source radix: "); scanf("%d", &sourceRadix); printf("Enter the target radix: "); scanf("%d", &targetRadix); char output[100]; convert(input, sourceRadix, targetRadix, output); printf("%s (%d) = %s (%d)\n", input, sourceRadix, output, targetRadix); return 0; } ``` 这个程序可以将任意进制数转换为任意进制,使用方法如下: 1. 运行程序。 2. 输入要转换的字。 3. 输入原始进制。 4. 输入目标进制。 5. 程序会输出转换后的字。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值