PHP四种基本排序算法示例


Posted in PHP onApril 09, 2015

许多人都说算法是程序的核心,算法的好坏决定了程序的质量。作为一个初级phper,虽然很少接触到算法方面的东西。但是对于基本的排序算法还是应该掌握的,它是程序开发的必备工具。这里介绍冒泡排序,插入排序,选择排序,快速排序四种基本算法,分析一下算法的思路。

前提:分别用冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中的值按照从小到大的顺序进行排序。

$arr(1,43,54,62,21,66,32,78,36,76,39);

1. 冒泡排序

思路分析:在要排序的一组数中,对当前还未排好的序列,从前往后对相邻的两个数依次进行比较和调整,让较大的数往下沉,较小的往上冒。即,每当两相邻的数比较后发现它们的排序与排序要求相反时,就将它们互换。

代码实现:

$arr=array(1,43,54,62,21,66,32,78,36,76,39); 
function bubbleSort($arr)
{ 
 $len=count($arr);
 //该层循环控制 需要冒泡的轮数
 for($i=1;$i<$len;$i++)
 { //该层循环用来控制每轮 冒出一个数 需要比较的次数
 for($k=0;$k<$len-$i;$k++)
 {
  if($arr[$k]>$arr[$k+1])
  {
   $tmp=$arr[$k+1];
   $arr[$k+1]=$arr[$k];
   $arr[$k]=$tmp;
  }
 }
 }
 return $arr;
}

2. 选择排序

思路分析:在要排序的一组数中,选出最小的一个数与第一个位置的数交换。然后在剩下的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。

代码实现:

function selectSort($arr) {
//双重循环完成,外层控制轮数,内层控制比较次数
 $len=count($arr);
 for($i=0; $i<$len-1; $i++) {
 //先假设最小的值的位置
 $p = $i;
 for($j=$i+1; $j<$len; $j++) {
  //$arr[$p] 是当前已知的最小值
  if($arr[$p] > $arr[$j]) {
  //比较,发现更小的,记录下最小值的位置;并且在下次比较时采用已知的最小值进行比较。
  $p = $j;
  }
 }
 //已经确定了当前的最小值的位置,保存到$p中。如果发现最小值的位置与当前假设的位置$i不同,则位置互换即可。
 if($p != $i) {
  $tmp = $arr[$p];
  $arr[$p] = $arr[$i];
  $arr[$i] = $tmp;
 }
 }
 //返回最终结果
 return $arr;
}

3.插入排序

思路分析:在要排序的一组数中,假设前面的数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序的。如此反复循环,直到全部排好顺序。

代码实现:

function insertSort($arr) {
 $len=count($arr); 
 for($i=1, $i<$len; $i++) {
 $tmp = $arr[$i];
 //内层循环控制,比较并插入
 for($j=$i-1;$j>=0;$j--) {
  if($tmp < $arr[$j]) {
  //发现插入的元素要小,交换位置,将后边的元素与前面的元素互换
  $arr[$j+1] = $arr[$j];
  $arr[$j] = $tmp;
  } else {
  //如果碰到不需要移动的元素,由于是已经排序好是数组,则前面的就不需要再次比较了。
  break;
  }
 }
 }
 return $arr;
}

4.快速排序 

思路分析:选择一个基准元素,通常选择第一个元素或者最后一个元素。通过一趟扫描,将待排序列分成两部分,一部分比基准元素小,一部分大于等于基准元素。此时基准元素在其排好序后的正确位置,然后再用同样的方法递归地排序划分的两部分。

代码实现:

function quickSort($arr) {
 //先判断是否需要继续进行
 $length = count($arr);
 if($length <= 1) {
 return $arr;
 }
 //选择第一个元素作为基准
 $base_num = $arr[0];
 //遍历除了标尺外的所有元素,按照大小关系放入两个数组内
 //初始化两个数组
 $left_array = array(); //小于基准的
 $right_array = array(); //大于基准的
 for($i=1; $i<$length; $i++) {
 if($base_num > $arr[$i]) {
  //放入左边数组
  $left_array[] = $arr[$i];
 } else {
  //放入右边
  $right_array[] = $arr[$i];
 }
 }
 //再分别对左边和右边的数组进行相同的排序处理方式递归调用这个函数
 $left_array = quick_sort($left_array);
 $right_array = quick_sort($right_array);
 //合并
 return array_merge($left_array, array($base_num), $right_array);
}
PHP 相关文章推荐
PHP 简单数组排序实现代码
Aug 05 PHP
PHP连接SQLServer2005 的问题解决方法
Jul 19 PHP
PHP中break及continue两个流程控制指令区别分析
Apr 18 PHP
php设计模式 Template (模板模式)
Jun 26 PHP
php_screw 1.5:php加密: 安装与使用详解
Jun 20 PHP
ThinkPHP模板比较标签用法详解
Jun 30 PHP
PHP中使用php5-ffmpeg撷取视频图片实例
Jan 07 PHP
PHP和C#可共用的可逆加密算法详解
Oct 26 PHP
WordPress迁移时一些常见问题的解决方法整理
Nov 24 PHP
php mysql实现mysql_select_db选择数据库
Dec 30 PHP
PHP使用file_get_contents发送http请求功能简单示例
Apr 29 PHP
ThinkPHP框架整合微信支付之Native 扫码支付模式一图文详解
Apr 09 PHP
Laravel 5 框架入门(三)
Apr 09 #PHP
Laravel 5 框架入门(二)构建 Pages 的管理功能
Apr 09 #PHP
Laravel 5 框架入门(一)
Apr 09 #PHP
Smarty中的注释和截断功能介绍
Apr 09 #PHP
PHP中使用hidef扩展代替define提高性能
Apr 09 #PHP
PHP JSON格式的中文显示问题解决方法
Apr 09 #PHP
Laravel 5框架学习之用户认证
Apr 09 #PHP
You might like
smarty+adodb+部分自定义类的php开发模式
2006/12/31 PHP
php入门学习知识点八 PHP中for循环基本应用之九九乘法口绝表
2011/07/14 PHP
为何说PHP引用是个坑,要慎用
2018/04/02 PHP
express的中间件bodyParser详解
2014/12/04 Javascript
纯javascript实现自动发送邮件
2015/10/21 Javascript
基于jQuery实现动态搜索显示功能
2016/05/05 Javascript
JS封装通过className获取元素的函数示例
2016/12/20 Javascript
JS中解决谷歌浏览器记住密码输入框颜色改变功能
2017/02/13 Javascript
AngularJS实现自定义指令与控制器数据交互的方法示例
2017/06/19 Javascript
JavaScript实现设置默认日期范围为最近40天的方法分析
2017/07/12 Javascript
使用vue制作探探滑动堆叠组件的实例代码
2018/03/07 Javascript
javascript动态创建对象的属性详解
2018/11/07 Javascript
浏览器事件循环与vue nextTicket的实现
2019/04/16 Javascript
Vue的编码技巧与规范使用详解
2019/08/28 Javascript
vue实现数字动态翻牌的效果(开箱即用)
2019/12/08 Javascript
JavaScript canvas绘制渐变颜色的矩形
2020/02/18 Javascript
使用Taro实现小程序商城的购物车功能模块的实例代码
2020/06/05 Javascript
js实现鼠标拖曳效果
2020/12/30 Javascript
Python中for循环和while循环的基本使用方法
2015/08/21 Python
Python中在脚本中引用其他文件函数的实现方法
2016/06/23 Python
Python3.5面向对象与继承图文实例详解
2019/04/24 Python
python 含子图的gif生成时内存溢出的方法
2019/07/07 Python
基于python traceback实现异常的获取与处理
2019/12/13 Python
Python装饰器的应用场景代码总结
2020/04/10 Python
python将unicode和str互相转化的实现
2020/05/11 Python
解决Python paramiko 模块远程执行ssh 命令 nohup 不生效的问题
2020/07/14 Python
LN-CC中国:高端男装和女装的奢侈时尚目的地
2019/09/14 全球购物
仓管员岗位职责范文
2013/11/08 职场文书
军训感想500字
2014/02/20 职场文书
工伤事故赔偿协议书范文
2014/09/24 职场文书
销售员未完成销售业绩的检讨书
2014/10/12 职场文书
2014年行政工作总结
2014/11/19 职场文书
酒店前台接待岗位职责
2015/04/02 职场文书
员工给公司的建议书
2019/06/24 职场文书
导游词之宁夏贺兰山岩画
2019/11/08 职场文书
JavaScript中MutationObServer监听DOM元素详情
2021/11/27 Javascript