有没有这样的感觉,排序算法虽然简单,但是没看过一次,一会就又忘了,所以有必要 自己使用实际的代码运行实现,才记忆牢固,为此Mark

//需求:将数组中元素,从大到小排列
$a = array(11, 22, 44, 66, 99, 88);

1. 冒泡排序
  /*将第1个数与第2个数,比较如果小于第2个数,就交换位置,依次与这些数比较。
   *紧接着是 第2个数做同样的事,直到最后一个数为止
   */

  1. //需求:将数组中元素,从大到小排列
    $a = array(11, 22, 44, 66, 99, 88);
    $sortArray = bubbleSort($a);
    print_r($sortArray);
  2.  
  3. function bubbleSort($array)
  4. {/*{{{*/
  5. $oldArray = $array;
  6. $newArray = array();
  7. $count = count($oldArray);
  8. for($i = 0; $i < $count; $i++)
  9. {/*{{{*/
  10. //初始化
  11. $newArray[$i] = $oldArray[$i];
  12.  
  13. for($j = $i+1; $j < $count; $j++)
  14. {
  15. if($oldArray[$j] > $newArray[$i])
  16. {
  17. $newArray[$i] = $oldArray[$j];
  18. //交换位置
  19. $tmp = $oldArray[$i];
  20. $oldArray[$i] = $oldArray[$j];
  21. $oldArray[$j] = $tmp;
  22. }
  23. }
  24. }/*}}}*/
  25.  
  26. return $newArray;
  27. }/*}}}*/

2. 快速排序
  /*以第一个数为基准,比这个数大的数放到左边的数组,比这个数大的数放到右边的数组,然后做递归操作。
   *最后将左边数组,这个数和右边数组做 数组的 array_merge操作就行了
   */

  1. //需求:将数组中元素,从大到小排列
    $a = array(11, 22, 44, 66, 99, 88);
    $sortArray = bubbleSort($a);
    print_r($sortArray);
  2.  
  3. function fastSort($oldArray)
  4. {/*{{{*/
  5. $newArray = array();
  6. $count = count($oldArray);
  7. if($count <= 1) return $oldArray;
  8. $stand = $oldArray[0];
  9. //初始化
  10. $left_array = array();
  11. $right_array = array();
  12. for($i = 1; $i < $count; $i++)
  13. {/*{{{*/
  14. if($oldArray[$i] > $stand)
  15. {
  16. $left_array[] = $oldArray[$i];
  17. }
  18. else
  19. {
  20. $right_array[] = $oldArray[$i];
  21. }
  22.  
  23. }/*}}}*/
  24.  
  25. //递归调用
  26. $left_array = fastSort($left_array);
  27. $right_array = fastSort($right_array);
  28.  
  29. //也可循环放入新数组中
  30. $newArray = array_merge($left_array, array($stand), $right_array);
  31. return $newArray;
  32. }/*}}}*/
  33.  

【算法】PHP实现冒泡排序和快速排序--防遗忘的更多相关文章

  1. 【PHP面试题】通俗易懂的两个面试必问的排序算法讲解:冒泡排序和快速排序

    又到了金三银四找工作的时间,相信很多开发者都在找工作或者准备着找工作了.一般应对面试,我们无可厚非的去刷下面试题.对于PHPer来说,除了要熟悉自己所做的项目,还有懂的基本的算法.下面来分享下PHP面 ...

  2. 排序算法——交换排序(冒泡排序、快速排序)(java)

    一.冒泡排序 时间复杂度:O(n^2) 公认最慢的排序,每次把最大/最小的放一边,原理: [57,68,59,52] [57,68,59,52] [57,59,68,52] [57,59,52,68] ...

  3. [C#][算法] 用菜鸟的思维学习算法 -- 马桶排序、冒泡排序和快速排序

    用菜鸟的思维学习算法 -- 马桶排序.冒泡排序和快速排序 [博主]反骨仔 [来源]http://www.cnblogs.com/liqingwen/p/4994261.html  目录 马桶排序(令人 ...

  4. PHP描述冒泡排序和快速排序算法

    使用PHP描述冒泡排序和快速排序算法,对象可以是一个数组.使用PHP描述顺序查找和二分查找(也叫做折半查找)算法,顺序查找必须考虑效率,对象可以是一个有序数组.写一个二维数组排序算法函数,能够具有通用 ...

  5. 八大排序方法汇总(选择排序,插入排序-简单插入排序、shell排序,交换排序-冒泡排序、快速排序、堆排序,归并排序,计数排序)

    2013-08-22 14:55:33 八大排序方法汇总(选择排序-简单选择排序.堆排序,插入排序-简单插入排序.shell排序,交换排序-冒泡排序.快速排序,归并排序,计数排序). 插入排序还可以和 ...

  6. 交换排序:冒泡排序vs快速排序

    在开发的过程中, 经常会遇到集合排序, 那么一般情况下, 我们都是使用list.OrderBy()的方式来排序, 也无需关注到里面算法的实现是个什么样子. 正好这几天准备回顾一下数据结构与算法. 首先 ...

  7. 程序员必知的8大排序(三)-------冒泡排序,快速排序(java实现)

    程序员必知的8大排序(一)-------直接插入排序,希尔排序(java实现) 程序员必知的8大排序(二)-------简单选择排序,堆排序(java实现) 程序员必知的8大排序(三)-------冒 ...

  8. 牛客网Java刷题知识点之插入排序(直接插入排序和希尔排序)、选择排序(直接选择排序和堆排序)、冒泡排序、快速排序、归并排序和基数排序(博主推荐)

    不多说,直接上干货! 插入排序包括直接插入排序.希尔排序. 1.直接插入排序: 如何写成代码: 首先设定插入次数,即循环次数,for(int i=1;i<length;i++),1个数的那次不用 ...

  9. 2017.12.9 Java中的排序---冒泡排序、快速排序、选择排序

    //冒泡排序 public class demo{ public static void main(String[] args) { int[] sum={2,9,10,1,5,88}; System ...

随机推荐

  1. PLSQL使用技巧

    PL/SQL Developer记住登陆密码    在使用PL/SQL Developer时,为了工作方便希望PL/SQL Developer记住登录Oracle的用户名和密码: 设置方法:PL/SQ ...

  2. Android_安卓为按钮控件绑定事件的五种方式

    一.写在最前面 本次,来介绍一下安卓中为控件--Button绑定事件的五种方式. 二.具体的实现 第一种:直接绑定在Button控件上: 步骤1.在Button控件上设置android:onClick ...

  3. SQL Server DDL触发器运用

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 基础知识(Rudimentary Knowledge) DDL运用场景(DDL Scene) ...

  4. 2014 年最热门的国人开发开源软件 TOP 100 - 开源中国社区

    不知道从什么时候开始,很多一说起国产好像就非常愤慨,其实大可不必.做开源中国六年有余,这六年时间国内的开源蓬勃发展,从一开始的使用到贡献,到推出自己很多的开源软件,而且还有很多软件被国外的认可.中国是 ...

  5. Android混淆代码

    Android代码混淆是必须的,java层代码如果不做混淆等于把源代码送人了.那如何做混淆呢? 之前一般都是提到采用proguard.cfg,但使用新版本ADT后没有这个文件了,取而代之的是progu ...

  6. 关于近段时间论坛型APP 的一段舍弃

    一直以为缓存务必要做的很好,好到什么程度呢,我曾这样想,用户在下滑数刷新的时候也要做到,先加载久缓存再加载新的,同时只改变旧的某些项.这样的想法真的很好!好到我花费了三天去设计数据库和服务器的 php ...

  7. android 通过访问 php 接受 or 传送数据

    先说传送数据,可以在 利用 php 代替传送,直接把 访问的url加上 xxx.php?informatin=xxxxxx 就行了 接收的看代码吧,详细注释. 首先是 我自己定义的php 文件 < ...

  8. WebGIS中基于AGS的画圆查询简析以及通过Polygon来构造圆的算法

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.背景 某个项目需求中需要在前端进行画圆查询,将圆范围上的多边形要素 ...

  9. 读取SD卡文件夹下的MP3文件和播放MP3文件

    首先获取SD卡path路径下的所有的MP3文件,并将文件名和文件大小存入List数组(此代码定义在FileUtils类中): /** * 读取目录中的Mp3文件的名字和大小 */ public Lis ...

  10. T-SQL CROSS APPLY、MERGE

    写在前面 刚才看项目里一个存储过程,也是好长时间没有使用Sql Server2008了,好多写法和函数感觉到陌生,这就遇到了CROSS APPLY 和MERGE的语法,两者之前完全没接触过. 所以专门 ...