php實現選擇排序

來源:互聯網
上載者:User

1,定義:選擇排序(Selection sort)是一種簡單直觀的排序演算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然後,再從剩餘未排序元素中繼續尋找最小(大)元素,然後放到已排序序列的末尾。以此類推,直到所有元素均排序完畢。

參考代碼:

<?php    //選擇排序(Selection sort)是一種簡單直觀的排序演算法。它的工作原理如下。首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然後,再從剩餘未排序元素中繼續尋找最小(大)元素,然後放到已排序序列的末尾。以此類推,直到所有元素均排序完畢。        function selectSort(&$arr){        //定義進行交換的變數        $temp=0;        for($i=0;$i<count($arr)-1;$i++){            //假設$i就是最小值            $valmin=$arr[$i];            //記錄最小值的下標            $minkey=$i;            for($j=$i+1;$j<count($arr);$j++){                //最小值大於後面的數就進行交換                    if($valmin>$arr[$j]){                    $valmin=$arr[$j];                    $minkey=$j;                }            }            //進行交換            $temp=$arr[$i];            $arr[$i]=$arr[$minkey];            $arr[$minkey]=$temp;        }    }             $arr=array(7,5,0,4,-1);    selectSort($arr);    print_r($arr);?>

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.