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 相关文章推荐
初探PHP5
Oct 09 PHP
PHP 中文乱码解决办法总结分析
Jul 30 PHP
PHP 危险函数全解析
Sep 09 PHP
php Xdebug 调试扩展的安装与使用.
Mar 13 PHP
php批量缩放图片的代码[ini参数控制]
Feb 11 PHP
php打印一个边长为N的实心和空心菱型的方法
Mar 02 PHP
PHP将进程作为守护进程的方法
Mar 19 PHP
微信获取用户地理位置信息的原理与步骤
Nov 12 PHP
php外部执行命令函数用法小结
Oct 11 PHP
PHP 芝麻信用接入的注意事项
Dec 01 PHP
php使用curl_init()和curl_multi_init()多线程的速度比较详解
Aug 15 PHP
Laravel 验证码认证学习记录小结
Dec 20 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(5) 类和对象
2010/02/16 PHP
php内核解析:PHP中的哈希表
2014/01/30 PHP
thinkphp5.1 文件引入路径问题及注意事项
2018/06/13 PHP
通过实例解析PHP数据类型转换方法
2020/07/11 PHP
九种js弹出对话框的方法总结
2013/03/12 Javascript
js自动下载文件到本地的实现代码
2013/04/28 Javascript
浅析Js中的单引号与双引号问题
2013/11/06 Javascript
如何动态的导入js文件具体该怎么实现
2014/01/14 Javascript
js实现的捐赠管理完整实例
2015/01/20 Javascript
js图片卷帘门导航菜单特效代码分享
2015/09/10 Javascript
很全面的JavaScript常用功能汇总集合
2016/01/22 Javascript
避免jQuery名字冲突 noConflict()方法
2016/07/30 Javascript
JS查找字符串中出现次数最多的字符
2016/09/05 Javascript
JS实现的图片选择顺序切换和循环切换功能示例【测试可用】
2018/12/28 Javascript
浅谈vue在html中出现{{}}的原因及解决方式
2020/11/16 Javascript
[02:46]解说DC:感谢430陪伴我们的DOTA2国际邀请赛岁月
2016/06/29 DOTA
[55:35]VGJ.S vs Mski Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
python使用cStringIO实现临时内存文件访问的方法
2015/03/26 Python
详解python中字典的循环遍历的两种方式
2017/02/07 Python
python3爬虫获取html内容及各属性值的方法
2018/12/17 Python
python爬虫神器Pyppeteer入门及使用
2019/07/13 Python
对Django项目中的ORM映射与模糊查询的使用详解
2019/07/18 Python
django中的图片验证码功能
2019/09/18 Python
Python利用全连接神经网络求解MNIST问题详解
2020/01/14 Python
python如何实现复制目录到指定目录
2020/02/13 Python
Python进程间通信multiprocess代码实例
2020/03/18 Python
aec加密 php_php aes加密解密类(兼容php5、php7)
2021/03/14 PHP
HTML5 LocalStorage 本地存储刷新值还在
2017/03/10 HTML / CSS
个人简历中自我评价
2014/02/11 职场文书
擅自离岗检讨书
2014/09/12 职场文书
工伤事故赔偿协议书(标准)
2014/09/29 职场文书
离职证明格式样本
2015/06/12 职场文书
Python如何识别银行卡卡号?
2021/06/10 Python
【海涛解说】史上最给力比赛,挑战DOTA极限
2022/04/01 DOTA
【DOTA2】总决赛血虐~ XTREME GAMING vs MAGMA - OGA DOTA PIT 2022 CN
2022/04/02 DOTA
六个好看实用的 HTML + CSS 后台登录入口页面
2022/04/28 HTML / CSS