復制代碼 代碼如下:
//取進制位上的數值
function getRemainder($num, $bin, $pos, &$result = 0){
//author lianq.net
//$num 數值,十進制
//$bin 要轉換的進制
//$pos 位數
$real_len = log($num, $bin);//對數,求原值長度
$floor_len = floor($real_len);//捨去求整
$base = pow($bin, $pos-1);//基數
$divisor = pow($bin,$pos);//除數
if($num >= $divisor){
$new_num = $num % pow($bin, $floor_len);
getRemainder($new_num, $bin, $pos, $result);
}else{
$result = floor($num / $base);
}
return $result;
}
//比如,數值16轉換為9進制時,它的第一位上的數值是多少?
$a = getRemainder(16,9, 1);
echo $a;//輸出7