php教程 php手册 [PHP] 排序和查找算法 - 陶士涵

[PHP] 排序和查找算法 - 陶士涵

May 20, 2016 am 11:39 AM

知乎:冒泡排序(bubble sort)的原理是什么?

 

潘屹峰:

冒泡排序的原理可以顾名思义:把每个数据看成一个气泡,按初始顺序自底向上依次对两两气泡进行比较,对上重下轻的气泡交换顺序(这里用气泡轻、重表示数据大、小),保证轻的气泡总能浮在重的气泡上面,直到最轻的气泡浮到最上面;保持最后浮出的气泡不变,对余下气泡循环上述步骤,直到所有气泡从轻到重排列完毕。

 

Nerd Leo

在实际项目中应该使用PHP自带的库函数。冒泡和快排要在大数据量下才有明显的性能差异 。在几个常用的小数据排序算法中,冒泡是实际效率最差的,选择排序或插入排序

 

<span style="color: #800080;">$nums</span>=<span style="color: #0000ff;">array</span>(7,2,1,3,4,5,6<span style="color: #000000;">);
</span><span style="color: #800080;">$length</span>=<span style="color: #008080;">count</span>(<span style="color: #800080;">$nums</span><span style="color: #000000;">);
</span><span style="color: #0000ff;">for</span>(<span style="color: #800080;">$i</span>=0;<span style="color: #800080;">$i</span>$length;<span style="color: #800080;">$i</span>++<span style="color: #000000;">){
    </span><span style="color: #0000ff;">for</span>(<span style="color: #800080;">$j</span>=(<span style="color: #800080;">$length</span>-1);<span style="color: #800080;">$j</span>><span style="color: #800080;">$i</span>;<span style="color: #800080;">$j</span>--<span style="color: #000000;">){
        </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$nums</span>[<span style="color: #800080;">$j</span>]$nums[<span style="color: #800080;">$j</span>-1<span style="color: #000000;">]){
            </span><span style="color: #800080;">$temp</span>=<span style="color: #800080;">$nums</span>[<span style="color: #800080;">$j</span><span style="color: #000000;">];
            </span><span style="color: #800080;">$nums</span>[<span style="color: #800080;">$j</span>]=<span style="color: #800080;">$nums</span>[<span style="color: #800080;">$j</span>-1<span style="color: #000000;">];
            </span><span style="color: #800080;">$nums</span>[<span style="color: #800080;">$j</span>-1]=<span style="color: #800080;">$temp</span><span style="color: #000000;">;
        }
    }
}</span>
로그인 후 복사

 

 

知乎:想请教一下学算法的大神,快速排序和二叉树排序哪个快一点?

本人对排序算法了解不多,但是大概知道快速排序和二叉树排序的原理。两者在排序速度上差别大吗?恳请大神给我这个小白科普一下。

 

Yan Gu

首先,默认题主说串行的情形,我猜题主并不一定知道任何一个并行排序算法。

 

其次,搜索树排序是一个general的概念,默认姑且为“随机二叉搜索树”。用它排序的computational DAG完全等价于快速排序(具体分析自己去看1987年那篇论文),但是虽然计算是完全一样的,计算的顺序却大不相同,因而快排的cache locality要好的多得多(不懂请自行维基),所以会快得多。

 

当然二叉树排序并不是没有优点。他的最大优势就在于并不是swap-based sorting。导致的缺点虽然是memory access pattern的导致有很多random access,但是优点是并不用频繁的写内存,于是在一些特殊setting下是有优势的。(如果蛋疼想知道具体内容,请去我主页把那些关于sortingpaper看了就懂了。)

 

白如冰:

快排和二叉搜索树本质上是一样一样的。

快排的partion不就是分左右子树么。

快速排序:

 

<span style="color: #0000ff;">function</span> quick_sort(<span style="color: #800080;">$array</span><span style="color: #000000;">){
    </span><span style="color: #0000ff;">if</span> (<span style="color: #008080;">count</span>(<span style="color: #800080;">$array</span>) return <span style="color: #800080;">$array</span><span style="color: #000000;">;
    </span><span style="color: #800080;">$key</span>=<span style="color: #800080;">$array</span>[0<span style="color: #000000;">];
    </span><span style="color: #800080;">$left_arr</span>=<span style="color: #0000ff;">array</span><span style="color: #000000;">();
    </span><span style="color: #800080;">$right_arr</span>=<span style="color: #0000ff;">array</span><span style="color: #000000;">();
    </span><span style="color: #0000ff;">for</span>(<span style="color: #800080;">$i</span>=1;<span style="color: #800080;">$i</span>count(<span style="color: #800080;">$array</span>);<span style="color: #800080;">$i</span>++<span style="color: #000000;">){
        </span><span style="color: #0000ff;">if</span>(<span style="color: #800080;">$array</span>[<span style="color: #800080;">$i</span>]$key<span style="color: #000000;">){
            </span><span style="color: #800080;">$left_arr</span>[]=<span style="color: #800080;">$array</span>[<span style="color: #800080;">$i</span><span style="color: #000000;">];
        }</span><span style="color: #0000ff;">else</span><span style="color: #000000;">{
            </span><span style="color: #800080;">$right_arr</span>[]=<span style="color: #800080;">$array</span>[<span style="color: #800080;">$i</span><span style="color: #000000;">];
        }
        
    }
    </span><span style="color: #800080;">$left_arr</span>=quick_sort(<span style="color: #800080;">$left_arr</span><span style="color: #000000;">);
    </span><span style="color: #800080;">$right_arr</span>=quick_sort(<span style="color: #800080;">$right_arr</span><span style="color: #000000;">);
    </span><span style="color: #0000ff;">return</span> <span style="color: #008080;">array_merge</span>(<span style="color: #800080;">$left_arr</span>,<span style="color: #0000ff;">array</span>(<span style="color: #800080;">$key</span>),<span style="color: #800080;">$right_arr</span><span style="color: #000000;">);
    
}</span>
로그인 후 복사

 

二分查找:

<span style="color: #0000ff;">function</span> bin_sch(<span style="color: #800080;">$array</span>, <span style="color: #800080;">$low</span>, <span style="color: #800080;">$high</span>, <span style="color: #800080;">$k</span><span style="color: #000000;">){
    </span><span style="color: #0000ff;">if</span> (<span style="color: #800080;">$low</span> $high<span style="color: #000000;">){
        </span><span style="color: #800080;">$mid</span> = <span style="color: #008080;">intval</span>((<span style="color: #800080;">$low</span>+<span style="color: #800080;">$high</span>)/2<span style="color: #000000;">);
        </span><span style="color: #0000ff;">if</span> (<span style="color: #800080;">$array</span>[<span style="color: #800080;">$mid</span>] == <span style="color: #800080;">$k</span><span style="color: #000000;">){
            </span><span style="color: #0000ff;">return</span> <span style="color: #800080;">$mid</span><span style="color: #000000;">;
        }</span><span style="color: #0000ff;">elseif</span> (<span style="color: #800080;">$k</span> $array[<span style="color: #800080;">$mid</span><span style="color: #000000;">]){
            </span><span style="color: #0000ff;">return</span> bin_sch(<span style="color: #800080;">$array</span>, <span style="color: #800080;">$low</span>, <span style="color: #800080;">$mid</span>-1, <span style="color: #800080;">$k</span><span style="color: #000000;">);
        }</span><span style="color: #0000ff;">else</span><span style="color: #000000;">{
            </span><span style="color: #0000ff;">return</span> bin_sch(<span style="color: #800080;">$array</span>, <span style="color: #800080;">$mid</span>+1, <span style="color: #800080;">$high</span>, <span style="color: #800080;">$k</span><span style="color: #000000;">);
        }
    }
    </span><span style="color: #0000ff;">return</span> -1<span style="color: #000000;">;
}</span>
로그인 후 복사

 

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)