您的位置:首页 > 其它

HDU - 2031进制转化

2017-11-23 22:53 85 查看

题目连接:HDU - 2031

题目描述:

输入一个十进制数N,将它转换成R进制数输出。

Input 输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<>10)。

Output 为每个测试实例输出转换后的数,每个输出占一行。如果R大于10,则对应的数字规则参考16进制(比如,10用A表示,等等)。
Sample Input
7 2
23 12
-4 3

Sample Output
111
1B
-11


利用字符串处理

代码:

#include<stdio.h>
#include<math.h>
char s[1010] ;
int main() {
int n , r ;
while( scanf("%d%d" , &n , &r ) != EOF ) {
int d = 0 , c = abs( n ) ;//取绝对值
if( r > 10 ) {//如果R大于10,则对应的数字规则参考16进制
while( c>0 ) {
if( c%r >= 10 ) {//比如,10用A表示,等等
s[d++] = 65 + ( c%r - 10 ) ;
}
else s[d++] = c%r + '0' ;
c /= r ;
}
}
else {
while( c>0 ) {
s[d++] = c%r + '0' ;
c /= r ;
}
}
if( n<0 ) printf("-") ;//若为负数,先输出负号
for( int i=d-1 ; i>=0 ; i-- ) {
printf("%c" , s[i] ) ;//由下至上输出
if( i == 0 ) printf("\n") ;
}
}
return 0 ;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  进制