进制转换(change)

大家好,我是代码乌拉。今天,我要给大家打断程序。它叫 进制转换(change)

题目如下:

问题描述

请你编一程序实现两种不同进制之间的数据转换。

输入描述

共有三行,第一行是一个正整数,表示需要转换的数的进制n(2≤n≤16),第二行是一个n进制数,若n>10则用大写字母A~F表示数码10~15,并且该n进制数对应的十进制的值不超过1000000000,第三行也是一个正整数,表示转换之后的数的进制m(2≤m≤16)。

输出描述

仅一行,包含一个正整数,表示转换之后的m进制数。

样例输入

输入数据 1

16
FF
2

Copy

输出数据 1

11111111

先别看答案,自己做做看。

好了,答案如下

#include<bits/stdc++.h>
using namespace std; 
int n,m;
long long i,s,t,k;
char st1[200],st2[200];
int main()
{ 
	cin>>n>>st1>>m;
	t=1;
	for(int i=strlen(st1)-1;i>=0;i--)
	{
		if(st1[i]<='9')k=st1[i]-48;
			else k=st1[i]-55;
		s+=k*t;
		t=t*n;
	}
	k=0;
	while(s)
	{
		t=s%m;
		k++;
		if(t<=9) st2[k]=t+48;
			else st2[k]=t+55;
			s=s/m;
	}
	for (int i=k;i>=1;i--)cout<<st2[i];
    return 0;
}

答案不唯一,欢迎大家到 zhujioj.tk 进制转换(change)去验证。


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值