php冒泡排序與快速排序演算法

來源:互聯網
上載者:User
本篇文章主要介紹php冒泡排序與快速排序演算法,感興趣的朋友參考下,希望對大家有所協助。

代碼如下:

$a=array('3','8','1','4','11','7');print_r($a);$len = count($a);//從小到大for($i=1;$i<$len;$i++){for($j=$len-1;$j>=$i;$j--)if($a[$j]<$a[$j-1]){//如果是從大到小的話,只要在這裡的判斷改成if($b[$j]>$b[$j-1])就可以了 $x=$a[$j]; $a[$j]=$a[$j-1]; $a[$j-1]=$x;}}print_r($a);j//另一種方法 從小到大$b=array('4','3','8','9','2','1');$len=count($b);for($k=1;$k<$len;$k++){for($j=$len-1,$i=0;$i<$len-$k;$i++,$j--)if($b[$j]<$b[$j-1]){//如果是從大到小的話,只要在這裡的判斷改成if($b[$j]>$b[$j-1])就可以了 $tmp=$b[$j]; $b[$j]=$b[$j-1]; $b[$j-1]=$tmp;}print_r($b);echo "";}//下面的這個執行效率更高function maopao($arr){ $len = count($arr); for($i=1; $i<$len; $i++)//最多做n-1趟排序 { $flag = false;  //本趟排序開始前,交換標誌應為假 for($j=$len-1;$j>=$i;$j--) {  if($arr[$j]<$arr[$j-1])//交換記錄  {//如果是從大到小的話,只要在這裡的判斷改成if($arr[$j]>$arr[$j-1])就可以了   $x=$arr[$j];   $arr[$j]=$arr[$j-1];   $arr[$j-1]=$x;   $flag = true;//發生了交換,故將交換標誌置為真  } } if(! $flag)//本趟排序未發生交換,提前終止演算法 return $arr;   }}$shuz = array('2','4','1','8','5');$bb = maopao($shuz);print_r($bb);// 快速排序function kuaisu($arr){  $len = count($arr);  if($len <= 1){    return $arr;  }  $key = $arr[0];  $left_arr = array();  $right_arr = array();  for($i=1; $i<$len;$i++){    if($arr[$i] <= $key){      $left_arr[] = $arr[$i];    }else{      $right_arr[] = $arr[$i];    }  }  $left_arr = kuaisu($left_arr);  $right_arr = kuaisu($right_arr);  return array_merge($left_arr, array($key), $right_arr);}$arr = array(23,98,54,2,9,62,34);print_r(kuaisu($arr));

總結:以上就是本篇文的全部內容,希望能對大家的學習有所協助。

相關推薦:

php中浮點數運算執行個體分析

PHP定時任務擷取access_token的方法執行個體分享

PHP實現擷取使用者用戶端真實IP的解決方案

聯繫我們

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