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配置文件中最常用四个ini函数
Mar 19 PHP
php 中的4种标记风格介绍
May 10 PHP
php使用qr生成二维码的示例分享
Jan 20 PHP
php中filter_input函数用法分析
Nov 15 PHP
thinkphp普通查询与表达式查询实例分析
Nov 24 PHP
CentOS下PHP7的编译安装及MySQL的支持和一些常见问题的解决办法
Dec 17 PHP
php生成mysql的数据字典
Jul 07 PHP
PHP正则表达式处理函数(PCRE 函数)实例小结
May 09 PHP
Thinkphp5框架ajax接口实现方法分析
Aug 28 PHP
PHP用swoole+websocket和redis实现web一对一聊天
Nov 05 PHP
PHP实现基本留言板功能原理与步骤详解
Mar 26 PHP
aec加密 php_php aes加密解密类(兼容php5、php7)
Mar 14 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
example1.php
2006/10/09 PHP
计算一段日期内的周末天数的php代码(星期六,星期日总和)
2009/11/12 PHP
PHP遍历数组的几种方法
2012/03/22 PHP
PHP生成唯一订单号的方法汇总
2015/04/16 PHP
PHP PDOStatement::rowCount讲解
2019/02/01 PHP
Thinkphp 框架扩展之类库扩展操作详解
2020/04/23 PHP
JavaScript获取客户端计算机硬件及系统等信息的方法
2014/01/02 Javascript
通过url查找a元素并点击
2014/04/09 Javascript
深入探讨JavaScript、JQuery屏蔽网页鼠标右键菜单及禁止选择复制
2014/06/10 Javascript
nodejs教程之异步I/O
2014/11/21 NodeJs
JavaScript点击按钮后弹出透明浮动层的方法
2015/05/11 Javascript
全面解析标签页的切换方式
2016/08/21 Javascript
如何制作幻灯片(代码分享)
2017/01/06 Javascript
jQuery中on方法使用注意事项详解
2017/02/15 Javascript
Node.js设置CORS跨域请求中多域名白名单的方法
2017/03/28 Javascript
vue.js 初体验之Chrome 插件开发实录
2017/05/13 Javascript
vue2.0 elementUI制作面包屑导航栏
2018/02/22 Javascript
vue.js 打包时出现空白页和路径错误问题及解决方法
2019/06/26 Javascript
Vue + Element-ui的下拉框el-select获取额外参数详解
2020/08/14 Javascript
[00:56]跨越时空加入战场 全新祈求者身心“失落奇艺侍祭”展示
2019/07/20 DOTA
python利用paramiko连接远程服务器执行命令的方法
2017/10/16 Python
Python基于win32ui模块创建弹出式菜单示例
2018/05/09 Python
Tensorflow中使用tfrecord方式读取数据的方法
2018/06/19 Python
解决使用export_graphviz可视化树报错的问题
2019/08/09 Python
基于python求两个列表的并集.交集.差集
2020/02/10 Python
服务器端jupyter notebook映射到本地浏览器的操作
2020/04/14 Python
Python基于正则表达式实现计算器功能
2020/07/13 Python
解决Firefox下不支持outerHTML问题代码分享
2014/06/04 HTML / CSS
银行存款证明样本
2014/01/17 职场文书
安全目标管理责任书
2014/07/25 职场文书
我的大学四年规划书范文2014
2014/09/26 职场文书
关于成立领导小组的通知
2015/04/23 职场文书
因身体原因离职的辞职信范文
2015/05/12 职场文书
2015年社区党建工作汇报材料
2015/06/25 职场文书
Python中相见恨晚的技巧
2021/04/13 Python
一文解答什么是MySQL的回表
2022/08/05 MySQL