外星人的语言(PAT)

1.题目描述

nowcoder费了很大劲,终于和地外文明联系上。我们地球人通常有10根手指,因此我们习惯用10进制的数,而外星人的手指有16跟、8根等不等的数目,因此他们使用与我们不同的进制。为了方便沟通,需要你开发一款工具,把地球人的10进制转换成外星人的R进制形式。

2.输入描述:

输入有多行。
每行包括两个正整数n和R,其中2≤R≤16。
输入直到文件结束为止。

3.输出描述:

对于每个用例,输出n对应的R进制形式。
超过10进制的数,10用A表示、11用B表示,依次类推。

4.输入例子:

1989 2
1119 16

5.输出例子:

11111000101
45F

6.解题思路:

1、这实际就是一个进制转化题,十进制的转化是非常简单的,利用辗转相除法求余数即可
2、首先我们要根据目标进制取余数,因为包含目标进制存在八进制、十六进制,也就可能会出现字母,所以我们用一个字符串来存储目标进制
3、每次取余,判断范围后转化为字符类型存入字符串数组,然后相除
4、最后倒序输出字符串数组,即可得到目标进制

7.源代码:

#include<stdio.h>
int main()
{
	int n,r;
	char s[100];
	while(scanf("%d %d",&n,&r)!=-1)
	{
		int i,k=0;
		while(n)
		{
			if(n%r>=0&&n%r<=9)
				s[k++]=n%r+48;
			else
				s[k++]=n%r-10+'A';
			n=n/r;
		}
		for(i=k-1;i>=0;i--)
			printf("%c",s[i]);
		printf("\n");
		
	}
	return 0;
}
全部评论

相关推荐

斑驳不同:还为啥暴躁 假的不骂你骂谁啊
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务