文档章节

php四种基础算法:冒泡,选择,插入和快速排序法

 带刺的玫瑰
发布于 2014/01/06 11:45
字数 1136
阅读 14
收藏 0

许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣。作为一个初级phper,虽然很少接触到算法方面的东西 。但是对于冒泡排序,插入排序,选择排序,快速排序四种基本算法,我想还是要掌握的。下面是我按自己的理解,将四个方法分析一遍。
需求:分别用 冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中 的值按照从小到的顺序进行排序。 
$arr(1,43,54,62,21,66,32,78,36,76,39);

1. 冒泡排序法 
 *     思路分析:法如其名,就是像冒泡一样,每次从数组当中 冒一个最大的数出来。 
 *     比如:2,4,1    // 第一次 冒出的泡是4 
 *                2,1,4   // 第二次 冒出的泡是 2 
 *                1,2,4   // 最后就变成这样 

 

$arr=array(1,43,54,62,21,66,32,78,36,76,39);  function getpao($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 select_sort($arr) {//实现思路 双重循环完成,外层控制轮数,当前的最小值。内层 控制的比较次数    //$i 当前最小值的位置, 需要参与比较的元素    for($i=0, $len=count($arr); $i<$len-1; $i++) {        //先假设最小的值的位置        $p = $i;        //$j 当前都需要和哪些元素比较,$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.插入排序法 

插入排序法思路:将要排序的元素插入到已经 假定排序号的数组的指定位置。

function insert_sort($arr) {    //区分 哪部分是已经排序好的    //哪部分是没有排序的    //找到其中一个需要排序的元素    //这个元素 就是从第二个元素开始,到最后一个元素都是这个需要排序的元素    //利用循环就可以标志出来    //i循环控制 每次需要插入的元素,一旦需要插入的元素控制好了,    //间接已经将数组分成了2部分,下标小于当前的(左边的),是排序好的序列    for($i=1, $len=count($arr); $i<$len; $i++) {        //获得当前需要比较的元素值。        $tmp = $arr[$i];        //内层循环控制 比较 并 插入        for($j=$i-1;$j>=0;$j--) {   //$arr[$i];//需要插入的元素; $arr[$j];//需要比较的元素            if($tmp < $arr[$j]) {                //发现插入的元素要小,交换位置                //将后边的元素与前面的元素互换                $arr[$j+1] = $arr[$j];                //将前面的数设置为 当前需要交换的数                $arr[$j] = $tmp;            } else {                //如果碰到不需要移动的元素           //由于是已经排序好是数组,则前面的就不需要再次比较了。                break;            }        }    }    //将这个元素 插入到已经排序好的序列内。    //返回    return $arr;}

4.快速排序法  

function quick_sort($arr) {    //先判断是否需要继续进行    $length = count($arr);    if($length <= 1) {        return $arr;    }    //如果没有返回,说明数组内的元素个数 多余1个,需要排序    //选择一个标尺    //选择第一个元素    $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);}


© 著作权归作者所有

粉丝 0
博文 2
码字总数 3433
作品 0
桂林
私信 提问
php四种基础算法:冒泡,选择,插入和快速排序法

许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣。作为一个初级phper,虽然很少接触到算法方面的东西 。但是对于冒泡排序,插入排序,选择排序,快速排序四种基本算...

PHP86
2013/12/21
222
0
JAVA中运用数组的四种排序方法

JAVA中在运用数组进行排序功能时,一般有四种方法:快速排序法、冒泡法、选择排序法、插入排序法。 快速排序法主要是运用了Arrays中的一个方法Arrays.sort()实现。 冒泡法是运用遍历数组进...

IceRainYWC
2014/03/17
29
0
JAVA中运用数组的四种排序方法

JAVA中在运用数组进行排序功能时,一般有四种方法:快速排序法、冒泡法、选择排序法、插入排序法。 快速排序法主要是运用了Arrays中的一个方法Arrays.sort()实现。 冒泡法是运用遍历数组进...

闫三
2012/05/08
62
0
php 冒泡、选择、插入、快速排序算法

1. 冒泡排序法 思路分析:法如其名,就是像冒泡一样,每次从数组当中 冒一个最大的数出来。 $arr=array(2,32,51,68,66,100,78,10); function getpao($arr){ $len=count($arr);//设置一个空数...

ufo00001
2017/06/28
0
0
面试 13:基于排序算法的总结

浑浑噩噩,我们前面已经讲解了冒泡、插入、选择、归并、快排 5 种排序算法,其他的由于时间关系,我们就不一一例举了。 说到排序,不得不想到我们 JDK 中自带的 和 方法。这两个方法基本算是...

nanchen2251
2018/07/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

zookeeper - leader选举

让我们分析如何在ZooKeeper集合中选举leader节点。考虑一个集群中有N个节点。leader选举的过程如下: 所有节点创建具有相同路径 /app/leader_election/guid_ 的顺序、临时节点。 ZooKeeper集...

Canaan_
17分钟前
5
0
金九银十裸辞跳槽面试,却被面试官吊打

目前已经达到金九银十的阶段,相信有不少程序员蠢蠢欲动,开始出去试试水,想要跳槽涨薪了!有一个朋友就想改变现状,于是找了大量网上的面试题,强行记下之后,开始出去“试水”。 他试水之...

别打我会飞
20分钟前
4
0
Spring 官方出品应用监控度量指标门面类库Micrometer介绍

前言 上篇文章 Spring Boot 2.x 中的 Actuator 我们提到了在Spring Boot Actuator中的metirc指标。在Spring Boot 2.x中 官方引入了新的监控门面(facade)类库Micrometer。如果你对门面不是很清...

码农小胖哥
50分钟前
7
0
获取form对象

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"> <head> <......

前端老手
52分钟前
5
0
CSS-字体格式化

一、字体属性 1、自定字体的类型 font-family:黑体,华文彩云,宋体; 用逗号隔开多个字体类型 2、字体大小 font-size 取值:(1)以px为单位的数字 (2)以pt为单位的数字 (3)em/rem 3、...

wytao1995
55分钟前
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部