题目:
Problem Description
输入一个十进制数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>
int main()
{
long int n
; char yu
[
100
];
int yuu
,i
,t
,r
,flag
;
while(~scanf
(
"%d %d"
,&n
,&r
)) {
flag = 0 ;
i = 0 ; if(n < 0 ) {
n =-n ;
flag = 1 ; } while(n != 1 ) {
yuu =n %r ;
n =n /r ; if(yuu >= 10 ) { if(yuu == 10 ) {
yu [i ]= 'A' ;
i ++; } if(yuu == 11 ) {
yu [i ]= 'B' ;
i ++; } if(yuu == 12 ) {
yu [i ]= 'C' ;
i ++; } if(yuu == 13 ) {
yu [i ]= 'D' ;
i ++; } if(yuu == 14 ) {
yu [i ]= 'E' ;
i ++; } if(yuu == 15 ) {
yu [i ]= 'F' ;
i ++; } if(yuu == 16 ) {
yu [i ]= 'G' ;
i ++; } } else {
yu [i ]= '0' +yuu ;
i ++; } }
t =i ; if(flag == 1 )
printf ( "-" );
printf ( "1" ); for(i =t - 1 ;i >= 0 ;i --) {
printf ( "%c" ,yu [i ]); }
printf ( "\n" ); } return 0 ;}
flag = 0 ;
i = 0 ; if(n < 0 ) {
n =-n ;
flag = 1 ; } while(n != 1 ) {
yuu =n %r ;
n =n /r ; if(yuu >= 10 ) { if(yuu == 10 ) {
yu [i ]= 'A' ;
i ++; } if(yuu == 11 ) {
yu [i ]= 'B' ;
i ++; } if(yuu == 12 ) {
yu [i ]= 'C' ;
i ++; } if(yuu == 13 ) {
yu [i ]= 'D' ;
i ++; } if(yuu == 14 ) {
yu [i ]= 'E' ;
i ++; } if(yuu == 15 ) {
yu [i ]= 'F' ;
i ++; } if(yuu == 16 ) {
yu [i ]= 'G' ;
i ++; } } else {
yu [i ]= '0' +yuu ;
i ++; } }
t =i ; if(flag == 1 )
printf ( "-" );
printf ( "1" ); for(i =t - 1 ;i >= 0 ;i --) {
printf ( "%c" ,yu [i ]); }
printf ( "\n" ); } return 0 ;}
的问题,并且借鉴了一下大神的技巧和思路,代码量明显少了很多,并且也ac了,可喜可贺。
AC的代码:
#include<stdio.h>
#include<math.h>
#define maxn 1000
int main()
{
int n, r,arr[maxn],i;
while (~scanf("%d%d", &n, &r) && r != 10)
#include<math.h>
#define maxn 1000
int main()
{
int n, r,arr[maxn],i;
while (~scanf("%d%d", &n, &r) && r != 10)
{
if (n < 0) printf("-");
for (i = 0; n; i++)
if (n < 0) printf("-");
for (i = 0; n; i++)
{
arr[i] = abs(n%r);
n /= r;
}
for (i-=1;i>=0;i--)
arr[i] = abs(n%r);
n /= r;
}
for (i-=1;i>=0;i--)
{
if(r > 10 && arr[i] >= 10)
printf("%d", arr[i]);
else
printf("%c", 'A' - 10 + arr[i]) :
}
printf("\n");
}
printf("\n");
}
return 0;
}
}