php 36進制與10進制轉換

在追求更短的數(shù)字排序時我們常會用到36進制

/**

* @desc? im:十進制數(shù)轉換成三十六進制數(shù)

* @param (int)$num 十進制數(shù)

* return 返回:三十六進制數(shù)

*/

private function get_char($num) {

$num = intval($num);

if ($num <= 0)

return false;

$charArr = array("0","1","2","3","4","5","6","7","8","9",'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z');

$char = '';

do {

$key = ($num% 36);//取余

$char= $charArr[$key-1].$char;//余數(shù)

$num =floor(($num - $key))/36;

} while ($num > 0);

return $char;

}

/**

* @desc? im:三十六進制數(shù)轉換成十進制數(shù)

* @param (string)$char 三十六進制數(shù)

* return 返回:十進制數(shù)

*/

private? function get_num($char){

$array=array("0","1","2","3","4","5","6","7","8","9","A", "B", "C", "D","E", "F", "G", "H", "I", "J", "K", "L","M", "N", "O","P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y","Z");

$len=strlen($char);

for($i=0;$i<$len;$i++){

$index=array_search($char[$i],$array);

$sum+=($index+1)*pow(36,$len-$i-1);

}

return $sum;

}

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容