题记(19)--进制转换
目录
一、题目内容
求任意两个不同进制非负整数的转换(2进制~16进制),所给整数在long所能表达的范围之内。 不同进制的表示符号为(0,1,...,9,a,b,...,f)或者(0,1,...,9,A,B,...,F)。
二、输入描述
输入只有一行,包含三个整数a,n,b。a表示其后的n 是a进制整数,b表示欲将a进制整数n转换成b进制整数。a,b是十进制整数,2 =< a,b <= 16。 数据可能存在包含前导零的情况。
三、输出描述
可能有多组测试数据,对于每组数据,输出包含一行,该行有一个整数为转换后的b进制数。输出时字母符号全部用大写表示,即(0,1,...,9,A,B,...,F)。
四、输入输出示例
输入:
15 Aab3 7输出:
210306
AC代码~
五、完整C语言代码
#include<stdio.h>
#include<string.h>
int main() {
int a, b, i;
char s[100];
int tmp = 0;
scanf("%d%s%d", &a, s, &b);
int len = strlen(s);
int w = 1;
for (i = len - 1; i >= 0; i--) {
if ('a' <= s[i] && s[i] <= 'z') {
tmp += ( 10 + s[i] - 'a') * w;
} else if ('A' <= s[i] && s[i] <= 'Z') {
tmp += (10 + s[i] - 'A') * w;
} else
tmp += (s[i] - '0') * w;
w = w * a;
}
char ans[100];
i = 0;
while (tmp != 0) {
int t = tmp % b;
if (t >= 10)
ans[i++] = 'A' + t - 10;
else
ans[i++] = '0' + t;
tmp = tmp / b;
}
for (int j = i - 1; j >= 0; j--)
printf("%c", ans[j]);
printf("\n");
return 0;
}
原文地址:https://blog.csdn.net/ADDDDDDS/article/details/135706926
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!