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 09 PHP
在yii中新增一个用户验证的方法详解
Jun 20 PHP
Ubuntu12下编译安装PHP5.3开发环境
Mar 27 PHP
PHP中preg_match函数正则匹配的字符串长度问题
May 27 PHP
PHP页面输出时js设置input框的选中值
Sep 30 PHP
PHP请求远程地址设置超时时间的解决方法
Oct 29 PHP
PHP CodeIgniter分页实例及多条件查询解决方案(推荐)
May 20 PHP
Yii框架使用魔术方法实现跨文件调用功能示例
May 20 PHP
PHP使用PDO调用mssql存储过程的方法示例
Oct 07 PHP
PHP开发的文字水印,缩略图,图片水印实现类与用法示例
Apr 12 PHP
php + WebUploader实现图片批量上传功能
May 06 PHP
phpQuery采集网页实现代码实例
Apr 02 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
PHP如何将XML转成数组
2016/04/04 PHP
PHP Post获取不到非表单数据的问题解决办法
2018/02/27 PHP
PHP防止sql注入小技巧之sql预处理原理与实现方法分析
2019/12/13 PHP
Js 弹出框口并返回值的两种常用方法
2010/12/30 Javascript
jquery中交替点击事件toggle方法的使用示例
2013/12/08 Javascript
Javascript浅谈之this
2013/12/17 Javascript
jquery新的绑定事件机制on方法的使用方法
2014/04/15 Javascript
利用jQuery插件imgAreaSelect实现图片上传裁剪(同步显示图像位置信息)
2016/12/02 Javascript
基于JS实现弹出一个隐藏的div窗口body页面变成灰色并且不可被编辑
2016/12/14 Javascript
详解javascript表单的Ajax提交插件的使用
2016/12/29 Javascript
JS中利用localStorage防止页面动态添加数据刷新后数据丢失
2017/03/10 Javascript
基于Vue实现tab栏切换内容不断实时刷新数据功能
2017/04/13 Javascript
JS+Canvas绘制动态时钟效果
2017/11/10 Javascript
Javascript将图片的绝对路径转换为base64编码的方法
2018/01/11 Javascript
JS中touchstart事件与click事件冲突的解决方法
2018/03/12 Javascript
vue的style绑定background-image的方式和其他变量数据的区别详解
2018/09/03 Javascript
ES6字符串的扩展实例
2020/12/21 Javascript
Python实现一个简单的MySQL类
2015/01/07 Python
python简单分割文件的方法
2015/07/30 Python
在Mac OS系统上安装Python的Pillow库的教程
2015/11/20 Python
python+opencv实现动态物体追踪
2018/01/09 Python
Python爬虫beautifulsoup4常用的解析方法总结
2019/02/25 Python
多版本python的pip 升级后, pip2 pip3 与python版本失配解决方法
2019/09/11 Python
python中栈的原理及实现方法示例
2019/11/27 Python
Python2与Python3的区别点整理
2019/12/12 Python
Python实现上下文管理器的方法
2020/08/07 Python
外科实习自我鉴定
2013/10/06 职场文书
国贸专业个人求职信分享
2013/12/04 职场文书
金融行业职业生涯规划范文
2014/01/17 职场文书
理工学院学生自我鉴定
2014/02/23 职场文书
党员自我剖析材料范文
2014/10/06 职场文书
社区党员群众路线教育实践活动心得体会
2014/11/03 职场文书
年会邀请函范文
2015/01/30 职场文书
2016年党课培训学习心得体会
2016/01/07 职场文书
解决numpy和torch数据类型转化的问题
2021/05/23 Python
sql server偶发出现死锁的解决方法
2022/04/10 SQL Server