题目描述
给定一个十进制数M,以及需要转换的进制数N。将十进制数M转化为N进制数
输入描述:
输入为一行,M(32位整数)、N(2 ≤ N ≤ 16),以空格隔开。
输出描述:
为每个测试实例输出转换后的数,每个输出占一行。如果N大于9,则对应的数字规则参考16进制(比如,10用A表示,等等)
示例1
输入
7 2
输出
111
<?php
//给定一个十进制数M,以及需要转换的进制数N。将十进制数M转化为N进制数
$arr = [0,1,2,3,4,5,6,7,8,9,'A','B','C','D','E','F'];//余数表,余几就取几
$str = trim(fgets(STDIN));
$num = explode(" ", $str);
function jinzhi($num, $j, $arr){
$res = '';
$fuhao = '';
if($num < 0){//如果是负数,就加个负号。整数不做处理
$num = 0-$num;
$fuhao = '-';
}
while($num > 0){
$s=$num%$j;//取余数
$res.=$arr[$s];//拼接
$num = (int)($num/$j);
}
return $fuhao.strrev($res);//翻转后加上符号
}
echo jinzhi($num[0], $num[1], $arr);