HDU-2031,进制转换

简介: HDU-2031,进制转换

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>
#include<string.h>
int a[500];
int main()
{
  int m,n;
  while(~scanf("%d %d",&m,&n))
  {
    int j=0;
    if(m<0)//如果m是负数,先打印负号 
      printf("-");
    m=(m>0 ? m:-m);//统一将m转为正数计算 
    while(m!=0)
    {
      a[j++]=m%n;
      m/=n;
    }
    for(int i=j-1;i>=0;i--)
    {
      if(a[i]>=10)//大于10的要转换成字母 
        printf("%c",(a[i]%10)+'A');//对10求余只剩下个位,再加上A的ASCII码即可 
      else//不大于10的正常输出 
        printf("%d",a[i]);
    }
    printf("\n");
  }
  return 0;
}


相关文章
|
6月前
hdu1406 完数 (水题)
hdu1406 完数 (水题)
29 0
|
7月前
|
测试技术
华为机试HJ5:进制转换
华为机试HJ5:进制转换
每日一题1055:进制转换
题目描述: 编程,输入一个10进制正整数,然后输出它所对应的八进制数。 样例输入:
78 0
|
数据安全/隐私保护
HDU-2100,Lovekey(大数加法,26进制)
HDU-2100,Lovekey(大数加法,26进制)
|
存储 机器学习/深度学习 算法
[解题报告](第19讲) 进制转换(一) - 入门(2)
[解题报告](第19讲) 进制转换(一) - 入门
[解题报告](第19讲) 进制转换(一) - 入门(2)
|
存储 算法
[解题报告](第19讲) 进制转换(一) - 入门(1)
[解题报告](第19讲) 进制转换(一) - 入门
[解题报告](第19讲) 进制转换(一) - 入门(1)
|
Java
HDOJ(HDU) 2502 月之数(进制)
HDOJ(HDU) 2502 月之数(进制)
87 0
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
HDOJ/HDU 2352 Verdis Quo(罗马数字与10进制数的转换)
152 0
[解题报告](第20讲) 进制转换(二) - 进阶
[解题报告](第20讲) 进制转换(二) - 进阶
[解题报告](第20讲) 进制转换(二) - 进阶
|
存储 Java
HDOJ/HDU 2549 壮志难酬(取小数点后几位~)
HDOJ/HDU 2549 壮志难酬(取小数点后几位~)
82 0