php实现一个10进制转2进制的函数
  • 日期2020-04-18
  • 评论 0
  • 阅读 710
  • 分类 PHP笔记
  • 字数 561

php实现一个10进制转2进制的函数

十进制整数转换为二进制整数采用"除2取余,逆序排列"法。
具体做法是:用2整除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,如此进行,直到商为0时为止,
然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。
789=1100010101
789/2=394 余1 第10位
394/2=197 余0 第9位
197/2=98 余1 第8位
98/2=49 余0 第7位
49/2=24 余1 第6位
24/2=12 余0 第5位
12/2=6 余0 第4位
6/2=3 余0 第3位
3/2=1 余1 第2位
1/2得0 余1 第1位

function dec2bin($num)
{
    if (!is_int($num)) return false;
    $bin = '';
    while ($num > 1) {
        $bin .= $num % 2;
        $num = ($num - $num % 2) / 2;
    }
    return strrev($bin . $num);
}

echo dec2bin(3);

评论 (0)