题目:
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;
}
}