题解 | #数制转换#

数制转换

https://www.nowcoder.com/practice/8ef02ef8571b417d8c311a87861f7a03

#include <stdio.h>
#include <string.h>
int main() {
    int a, b;
    char n[50];
    while (scanf("%d%s%d", &a,n ,&b) != EOF) {
        int len=strlen(n);
        long long sum=0;
        for(int i=len-1,j=0;i>=0;i--,j++){  //转换10进制
            if(n[i]>=65 && n[i]<=70){
                sum+=(10+(n[i]-'A'))*pow(a,j);
            }
            else if(n[i]>=97 && n[i]<=102){
                sum+=(10+(n[i]-'a'))*pow(a,j);
            }
            else {
                sum+=(n[i]-'0')*pow(a,j);
            }
        }
        int k=0;
        char str[50];
        while(sum>0){  //转化b进制存入数组
            if(sum%b>=10)
            str[k++]='A'+(sum%b-10);
            else
            str[k++]=sum%b+'0';
            sum/=b;
        }
        for(int i=k-1;i>=0;i--){
            printf("%c",str[i]);
        }
    }
    return 0;
}

题目不难,思路清晰了就过了,先把数从a进制转化成10进制,然后把10进制转化为b进制,就解决了

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-03 18:13
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-29 17:30
找实习找着找着就要进入7月了,马上秋招也要开始了,找实习还有意义吗?
绝迹的星:有面就面, 没面上就当日薪4位数大佬免费培训, 面上了再考虑要不要实习
点赞 评论 收藏
分享
06-20 19:40
中原工学院 Java
网络存储:十几天不会让你拉人办卡就结束了吧?
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务