设为首页 收藏本站
查看: 1117|回复: 0

[经验分享] php四排序-冒泡排序

[复制链接]

尚未签到

发表于 2017-12-29 17:55:25 | 显示全部楼层 |阅读模式
  算法和数据结构是一个编程工作人员的内功,技术牛不牛,一般都会看这两点。作为php程序员, 提升技能当然也得学习算法。
  下面介绍四种入门级排序算法: 冒泡排序、选择排序、插入排序、快速排序。
  
  一、冒泡排序
  原理:对一组数据,比较相邻数据的大小,将值小数据在前面,值大的数据放在后面。   (以下都是升序排列,即从小到大排列)
  举例说明: $arr = array(6, 3, 8, 2, 9, 1);
  $arr 有6个数据,按照两两比较大小如下,注意  比较轮数 和 每轮比较次数
  第一轮排序:
  第一次比较  6和3比较 结果:3    6   8   2   9   1
  第二次比较  6和3比较 结果:3    6   8   2   9   1
  第三次比较  8和2比较 结果:3    6   2   8   9   1
  第四次比较  8和9比较 结果:3    6   2   8   9   1
  第五次比较  9和1比较 结果:3    6   2   8   1   9
  第一轮比较总结:1.排序第1轮、比较5次,没有获得从小到大的排序   2.因为每次比较都是大数往后靠,所以比较完成后,可以确定大数排在最后(9 已经冒泡冒出来了,下轮比较可以不用比较了 )
  第二轮排序:
  第一次比较  3和6比较 结果:3    6   2   8   1   9
  第二次比较  6和2比较 结果:3    2   6   8   1   9
  第三次比较  6和8比较 结果:3    2   6   8   1   9
  第四次比较  8和1比较 结果:3    2   6   1   8   9
  第二轮比较总结:1.排序第2轮、比较4次,没有获得从小到大的排序   2.冒泡出了 8,下轮不用比较8 了
  
  第三轮排序:
  第一次比较  3和2比较 结果:2    3   6   1   8   9
  第二次比较  3和6比较 结果:2    3   6   1   8   9
  第三次比较  6和1比较 结果:2    3   1   6   8   9
  第三轮比较总结:1.排序第3轮、比较3次,没有获得从小到大的排序   2.冒泡出了 6,下轮不用比较6 了
  第四轮排序:
  第一次比较  2和3比较 结果:2    3   1   6   8   9
  第二次比较  3和1比较 结果:2    1   3   6   8   9
  第四轮比较总结:1.排序第4轮、比较2次,没有获得从小到大的排序   2.冒泡出了 3,下轮不用比较3 了
  第五轮排序:
  第一次比较  2和1比较 结果:1   2   3   6   8   9
  第五轮比较总结:1.排序第5轮、比较1次,没有获得从小到大的排序   2.冒泡出了 2,由于还剩一个1,不用再比较了,至此通过5轮排序,完成整个排序。
  通过以上五轮排序,若干次比较,我们有理由推断出一个结论:
  对于一个长度为N的数组,我们需要排序 N-1 轮,每 i 轮 要比较 N-i 次。对此我们可以用双重循环语句,外层循环控制循环轮次,内层循环控制每轮的比较次数。
  

<?php  

  
  
function order($arr){$count = ($arr);$temp = 0;//外层控制排序轮次  for($i=0; $i<$count-1; $i++){
  //内层控制每轮比较次数
  for($j=0; $j< $count-1-$i; $j++){
  if($arr[$j] > $arr[$j+1]){
  $temp        = $arr[$j];
  $arr[$j]     = $arr[$j+1];
  $arr[$j+1]   = $temp;
  }
  }
  }
  
      return $arr;
  }
  

  

  $arr= array(6,3,8,2,9,1);
  
$res =  order($arr);
  
($res);
  

  参考链接:http://www.cnblogs.com/shen-hua/p/5422676.html

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-429441-1-1.html 上篇帖子: PHP中把数据库查询结果输出为json格式 下篇帖子: ueditor PHP版本使用方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表