Heim > Backend-Entwicklung > PHP-Tutorial > PHP-Binärsuche

PHP-Binärsuche

WBOY
Freigeben: 2016-07-29 09:12:56
Original
963 Leute haben es durchsucht

Für die binäre Suche muss das Array geordnet sein und die Effizienz ist O(logn)

<code><span><span><?php</span><span>#二分查找</span><span><span>function</span><span>binarySearch</span><span>(Array <span>$arr</span>, <span>$target</span>)</span> {</span><span>$low</span> = <span>0</span>;
        <span>$high</span> = count(<span>$arr</span>) - <span>1</span>;

        <span>while</span>(<span>$low</span> <= <span>$high</span>) {
            <span>$mid</span> = floor((<span>$low</span> + <span>$high</span>) / <span>2</span>);
            <span>#找到元素</span><span>if</span>(<span>$arr</span>[<span>$mid</span>] == <span>$target</span>) <span>return</span><span>$mid</span>;
            <span>#中元素比目标大,查找左部</span><span>if</span>(<span>$arr</span>[<span>$mid</span>] > <span>$target</span>) <span>$high</span> = <span>$mid</span> - <span>1</span>;
            <span>#重元素比目标小,查找右部</span><span>if</span>(<span>$arr</span>[<span>$mid</span>] < <span>$target</span>) <span>$low</span> = <span>$mid</span> + <span>1</span>;
        }

        <span>#查找失败</span><span>return</span><span>false</span>;
    }

    <span>$arr</span> = <span>array</span>(<span>1</span>, <span>3</span>, <span>5</span>, <span>7</span>, <span>9</span>, <span>11</span>);
    <span>$inx</span> = binarySearch(<span>$arr</span>, <span>1</span>);
    var_dump(<span>$inx</span>);
<span>?></span></span></code>
Nach dem Login kopieren
').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });

Das Obige stellt die PHP-Binärsuche vor, einschließlich einiger Aspekte des Inhalts. Ich hoffe, dass es für Freunde hilfreich ist, die sich für PHP-Tutorials interessieren.

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