进制转换
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
输入一个十进制数N,将它转换成R进制数输出。
输入
输入数据包含多个测试实例,每个测试实例包含两个整数N(32位整数)和R(2<=R<=16, R<>10)。
输出
为每个测试实例输出转换后的数,每个输出占一行。如果R大于10,则对应的数字规则参考16进制(比如,10用A表示,等等)。
示例输入
7 2 23 12 -4 3
示例输出
111 1B-11
#include<stdio.h> void f(int number,int R) { int Stack[1000]; int p=0; int flag=0; if(number==0) { printf("0\n"); return ; } if(number<0) { number*=-1; flag=1; } while(number) { if(number%R>=0&&number%R<=9) Stack[p++]=number%R; else Stack[p++]=number%R-10+'A'; number/=R; } p--; if(flag)printf("-"); while(p>=0) if(Stack[p]>=0&&Stack[p]<=9) printf("%d",Stack[p--]); else printf("%c",Stack[p--]); printf("\n"); } int main() { int number,R; while(~scanf("%d%d",&number,&R)) { f(number,R); } return 0; }