PHP實現經典演算法上 php程式設計經典300例 php遞迴演算法經典執行個體 php經典面試

來源:互聯網
上載者:User
前言

下面的是通過PHP實現經典演算法,並計算了耗時,可以通過耗時對比這幾種演算法的複雜度。

  • 插入排序
  • 冒泡排序
  • 選擇排序
  • 並歸排序
  • 快速排序

CODE

$arr = [];for ($i = 0; $i < 5000; $i++) {    $arr[] = rand(1, 10000);}//1 插入排序functioninsertionSort($arr){for ($i = 1; $i < count($arr); $i++) {        $tmp = $arr[$i]; //設定監視哨$key = $i - 1; //設定開始尋找的位置while ($key >= 0 && $tmp < $arr[$key]) { // 監視哨的值比尋找的值小 並且 沒有到此次查詢的第一個$arr[$key + 1] = $arr[$key];  //數組的值進行後移$key--;  //要尋找的位置後移        }        if (($key + 1) != $i) //放置監視哨$arr[$key + 1] = $tmp;    }    return$arr;}$insertion_start_time = microtime(true);$insertion_sort = insertionSort($arr);$insertion_end_time = microtime(true);$insertion_need_time = $insertion_end_time - $insertion_start_time;print_r("插入排序耗時:" . $insertion_need_time . "
");//2 冒泡排序functionbubbleSort($arr){for ($i = 0; $i < count($arr); $i++) { for ($j = 0; $j < $i + 1; $j++) { if ($arr[$j] < $arr[$j - 1]) { $temp = $arr[$j - 1]; $arr[$j - 1] = $arr[$j]; $arr[$j] = $temp; } } } return$arr;}$bubble_start_time = microtime(true);$bubble_sort = bubbleSort($arr);$bubble_end_time = microtime(true);$bubble_need_time = $bubble_end_time - $bubble_start_time;print_r("冒泡排序耗時:" . $bubble_need_time . "
");//3 選擇排序functionselectionSort($arr){$count = count($arr); for ($i = 0; $i < $count - 1; $i++) { //找到最小的值$min = $i; for ($j = $i + 1; $j < $count; $j++) { //由小到大排列if ($arr[$min] > $arr[$j]) { //表明當前最小的還比當前的元素大$min = $j; //賦值新的最小的 } } /*swap$array[$i]and$array[$min]即將當前內迴圈的最小元素放在$i位置上*/if ($min != $i) { $temp = $arr[$min]; $arr[$min] = $arr[$i]; $arr[$i] = $temp; } } return$arr;}$selection_start_time = microtime(true);$selection_sort = selectionSort($arr);$selection_end_time = microtime(true);$selection_need_time = $selection_end_time - $selection_start_time;print_r("選擇排序耗時:" . $selection_need_time . "
");//4 並歸排序//merge函數將指定的兩個有序數組(arr1arr2,)合并並且排序//我們可以找到第三個數組,然後依次從兩個數組的開始取資料哪個資料小就先取哪個的,然後刪除掉剛剛取過///的資料functional_merge($arrA, $arrB){$arrC = array(); while (count($arrA) && count($arrB)) { //這裡不斷的判斷哪個值小,就將小的值給到arrC,但是到最後肯定要剩下幾個值,//不是剩下arrA裡面的就是剩下arrB裡面的而且這幾個有序的值,肯定比arrC裡面所有的值都大所以使用$arrC[] = $arrA['0'] < $arrB['0'] ? array_shift($arrA) : array_shift($arrB); } return array_merge($arrC, $arrA, $arrB);}//歸併排序主程式functional_merge_sort($arr){$len = count($arr); if ($len <= 1) return$arr;//遞迴結束條件,到達這步的時候,數組就只剩下一個元素了,也就是分離了數組$mid = intval($len / 2);//取數組中間$left_arr = array_slice($arr, 0, $mid);//拆分數組0-mid這部分給左邊left_arr$right_arr = array_slice($arr, $mid);//拆分數組mid-末尾這部分給右邊right_arr$left_arr = al_merge_sort($left_arr);//左邊拆分完後開始遞迴合并往上走$right_arr = al_merge_sort($right_arr);//右邊拆分完畢開始遞迴往上走$arr = al_merge($left_arr, $right_arr);//合并兩個數組,繼續遞迴return$arr;}$merge_start_time = microtime(true);$merge_sort = al_merge_sort($arr);$merge_end_time = microtime(true);$merge_need_time = $merge_end_time - $merge_start_time;print_r("並歸排序耗時:" . $merge_need_time . "
");//5 快速排序functionquickSort(&$arr){if(count($arr)>1){ $k=$arr[0]; $x=array(); $y=array(); $_size=count($arr); for($i=1;$i<$_size;$i++){ if($arr[$i]<=$k){ $x[]=$arr[$i]; }elseif($arr[$i]>$k){ $y[]=$arr[$i]; } } $x=quickSort($x); $y=quickSort($y); return array_merge($x,array($k),$y); }else{ return$arr; }}$quick_start_time = microtime(true);$quick_sort = al_merge_sort($arr);$quick_end_time = microtime(true);$quick_need_time = $quick_end_time - $quick_start_time;print_r("快速排序耗時:" . $quick_need_time . "
");

耗時對比

插入排序耗時:1.2335460186005
冒泡排序耗時:2.6180219650269
選擇排序耗時:1.4159741401672
並歸排序耗時:0.17212891578674
快速排序耗時:0.16736888885498

參考資料

  • 演算法導論

').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($('
  • ').text(i)); }; $numbering.fadeIn(1700); }); });

    以上就介紹了PHP實現經典演算法上,包括了php,經典方面的內容,希望對PHP教程有興趣的朋友有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.