排序之冒泡排序(最佳化)-PHP

來源:互聯網
上載者:User

標籤:設定   例子   color   char   else   function   fun   func   數組   

 1 <?php 2     //佈建要求頭 3     header("content-type:text/html;charset=utf-8"); 4      5     //對冒泡排序進行最佳化:如果數組在傳進來或者遍曆一次兩次後 6     //就已經排好了 就不再進行排序操作 7  8     //例子: 9     $arr = array(1,2,3,6,4,12,1,85,1,3); //待排序數組10 //    $arr = range(1, 10000);11     12     function my_bubble_sort(&$arr){13         var_dump($arr);14         15         $arr_count = count($arr);16 17         //比較次數18         for($i=0; $i<$arr_count - 1; $i++){19             20             for($j=0; $j<$arr_count - $i - 1; $j++){21                 22                 //大向右移動,小向左移動(從大到小隻需要該一下符號)23                 if($arr[$j] > $arr[$j+1]){24                     //交換操作25                     $temp = $arr[$j];26                     $arr[$j] = $arr[$j + 1];27                     $arr[$j + 1] = $temp;28                     $flag = 1;29                 }30             }31 32             if(!$flag){33                 //如果$flag=0表示 小for迴圈沒有進行過1次資料交換(沒有進行過一次比較就可以說明該數組已經排序好)34                 //也就說不需要進行排序35                 break;36             }else{37                 $flag = 0;38             }39         }    40 41         var_dump($arr);42     }43 44      45 46     date_default_timezone_set (‘PRC‘);47     48 //    echo "start:" . date(‘H:i:s‘) . ‘<br>‘;49     my_bubble_sort($arr);50 //    echo "end:" . date(‘H:i:s‘);51 52 ?>

 

排序之冒泡排序(最佳化)-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.