• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

php冒泡排序与快速排序算法

php 搞代码 4年前 (2022-01-22) 25次浏览 已收录 0个评论

本篇文章主要介绍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;//发生了<strong style="color:transparent">¥本文来源gaodai#ma#com搞@@代~&码网^</strong><small>搞gaodaima代码</small>交换,故将交换标志置为真  } } 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的解决方法

以上就是php冒泡排序与快速排序算法的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:php冒泡排序与快速排序算法

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址