题目描述
给定一个十进制数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);