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;
}


相关文章
|
5月前
lanqiao OJ 649 算式900
lanqiao OJ 649 算式900
28 1
每日一题1055:进制转换
题目描述: 编程,输入一个10进制正整数,然后输出它所对应的八进制数。 样例输入:
123 0
LeetCode刷题(11)【简单】回文数&罗马数字转整数(C++)
LeetCode刷题(11)【简单】回文数&罗马数字转整数(C++)
LeetCode刷题(11)【简单】回文数&罗马数字转整数(C++)
|
存储 算法
[解题报告](第19讲) 进制转换(一) - 入门(1)
[解题报告](第19讲) 进制转换(一) - 入门
[解题报告](第19讲) 进制转换(一) - 入门(1)
|
存储 机器学习/深度学习 算法
[解题报告](第19讲) 进制转换(一) - 入门(2)
[解题报告](第19讲) 进制转换(一) - 入门
[解题报告](第19讲) 进制转换(一) - 入门(2)
|
数据安全/隐私保护
HDU-2100,Lovekey(大数加法,26进制)
HDU-2100,Lovekey(大数加法,26进制)
HDU-1061,Rightmost Digit(快速幂)
HDU-1061,Rightmost Digit(快速幂)
|
测试技术
HDU-1228,A + B(字符串处理)
HDU-1228,A + B(字符串处理)
HDU-1262,寻找素数对(素数打表)
HDU-1262,寻找素数对(素数打表)
|
Java 测试技术
HDOJ(HDU) 1877 又一版 A+B(进制、、)
HDOJ(HDU) 1877 又一版 A+B(进制、、)
107 0