Heim > Backend-Entwicklung > PHP-Tutorial > 算法 - php如何把一个20位的62进制的转回10进制字符串

算法 - php如何把一个20位的62进制的转回10进制字符串

WBOY
Freigeben: 2016-06-06 20:24:48
Original
1115 Leute haben es durchsucht

php如何把一个20位的62进制的转回10进制字符串。
目前通过

<code>    function dec62($n) {
        $base = 62;
        $index = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
        $ret = '';
        for($t = floor(log10($n) / log10($base)); $t >= 0; $t --) {
            $a = floor($n / pow($base, $t));
            $ret .= substr($index, $a, 1);
            $n -= $a * pow($base, $t);
        }
        return $ret;
    }</code>
Nach dem Login kopieren
Nach dem Login kopieren

可以把超长的十进制整数转到62进制,但是由于系统限制,转回来的时候会变成9.9999999991447E+27这样的数字。
需要一个算法,把超长的62进制转回10进制字符串。
可以用下面这个数字测试
9999999999144705880199999999999

回复内容:

php如何把一个20位的62进制的转回10进制字符串。
目前通过

<code>    function dec62($n) {
        $base = 62;
        $index = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
        $ret = '';
        for($t = floor(log10($n) / log10($base)); $t >= 0; $t --) {
            $a = floor($n / pow($base, $t));
            $ret .= substr($index, $a, 1);
            $n -= $a * pow($base, $t);
        }
        return $ret;
    }</code>
Nach dem Login kopieren
Nach dem Login kopieren

可以把超长的十进制整数转到62进制,但是由于系统限制,转回来的时候会变成9.9999999991447E+27这样的数字。
需要一个算法,把超长的62进制转回10进制字符串。
可以用下面这个数字测试
9999999999144705880199999999999

请使用 BCMath 做任意精度的加减乘除。

<code>function base62to10($n)
{
    $index = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    $n = strval($n);
    $len = strlen($n);
    $result = 0;
    $base = 1;
    for ($i = $len-1; $i >= 0; $i--) {
        $char = $n[$i];
        $d = strpos($index, $char);
        assert($d !== false);
        $result = bcadd($result, bcmul($d, $base));
        $base = bcmul($base, 62);
    }
    return $result;
}

echo base62to10('9999999999144705880199999999999'),"\n";</code>
Nach dem Login kopieren

首先,楼主的算法是不对的,因为我用9999999999144705880199999999999和9999999999144705880199999999998这个数测dec62(),发现输出结果是一样的。
我在php手册中看到了大神的算法(需要BCMath支持):

<code class="php">    function convBase($numberInput, $fromBaseInput, $toBaseInput){
        if ($fromBaseInput==$toBaseInput) return $numberInput;
        $fromBase = str_split($fromBaseInput,1);
        $toBase = str_split($toBaseInput,1);
        $number = str_split($numberInput,1);
        $fromLen=strlen($fromBaseInput);
        $toLen=strlen($toBaseInput);
        $numberLen=strlen($numberInput);
        $retval='';
        if ($toBaseInput == '0123456789')
        {
            $retval=0;
            for ($i = 1;$i </code>
Nach dem Login kopieren

用法:
1、十进制转62进制

<code class="php">echo convBase('9999999999144705880199999999999','0123456789','0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ');</code>
Nach dem Login kopieren

2、62进制转十进制

<code class="php">echo convBase('3nLqycbr6ZQsN1JJYX','0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ','0123456789');</code>
Nach dem Login kopieren

它支持任意形式的进制转换,详见 http://php.net/manual/en/function.base-convert.php

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage