【算法】PHP实现冒泡排序和快速排序--防遗忘
2016-11-05 22:36
447 查看
有没有这样的感觉,排序算法虽然简单,但是没看过一次,一会就又忘了,所以有必要 自己使用实际的代码运行实现,才记忆牢固,为此Mark
//需求:将数组中元素,从大到小排列
$a = array(11, 22, 44, 66, 99, 88);
1. 冒泡排序
/*将第1个数与第2个数,比较如果小于第2个数,就交换位置,依次与这些数比较。
*紧接着是 第2个数做同样的事,直到最后一个数为止
*/
2. 快速排序
/*以第一个数为基准,比这个数大的数放到左边的数组,比这个数大的数放到右边的数组,然后做递归操作。
*最后将左边数组,这个数和右边数组做 数组的 array_merge操作就行了
*/
//需求:将数组中元素,从大到小排列
$a = array(11, 22, 44, 66, 99, 88);
1. 冒泡排序
/*将第1个数与第2个数,比较如果小于第2个数,就交换位置,依次与这些数比较。
*紧接着是 第2个数做同样的事,直到最后一个数为止
*/
//需求:将数组中元素,从大到小排列 $a = array(11, 22, 44, 66, 99, 88); $sortArray = bubbleSort($a); print_r($sortArray); function bubbleSort($array) {/*{{{*/ $oldArray = $array; $newArray = array(); $count = count($oldArray); for($i = 0; $i < $count; $i++) {/*{{{*/ //初始化 $newArray[$i] = $oldArray[$i]; for($j = $i+1; $j < $count; $j++) { if($oldArray[$j] > $newArray[$i]) { $newArray[$i] = $oldArray[$j]; //交换位置 $tmp = $oldArray[$i]; $oldArray[$i] = $oldArray[$j]; $oldArray[$j] = $tmp; } } }/*}}}*/ return $newArray; }/*}}}*/
2. 快速排序
/*以第一个数为基准,比这个数大的数放到左边的数组,比这个数大的数放到右边的数组,然后做递归操作。
*最后将左边数组,这个数和右边数组做 数组的 array_merge操作就行了
*/
//需求:将数组中元素,从大到小排列 $a = array(11, 22, 44, 66, 99, 88); $sortArray = bubbleSort($a); print_r($sortArray); function fastSort($oldArray) {/*{{{*/ $newArray = array(); $count = count($oldArray); if($count <= 1) return $oldArray; $stand = $oldArray[0]; //初始化 $left_array = array(); $right_array = array(); for($i = 1; $i < $count; $i++) {/*{{{*/ if($oldArray[$i] > $stand) { $left_array[] = $oldArray[$i]; } else { $right_array[] = $oldArray[$i]; } }/*}}}*/ //递归调用 $left_array = fastSort($left_array); $right_array = fastSort($right_array); //也可循环放入新数组中 $newArray = array_merge($left_array, array($stand), $right_array); return $newArray; }/*}}}*/
相关文章推荐
- 啊哈!算法 - 桶排序,冒泡排序,快速排序 - PHP实现
- 快速排序 php实现 算法学习
- 冒泡排序、选择排序、堆排序、快速排序、插入排序算法复杂度分析与算法实现(自己总结与转)
- 基本算法简单实现-二分法查找、合并排序、冒泡排序、插入排序、选择排序、快速排序
- 内部排序冒泡排序、插入排序、选择排序、快速排序的算法和PHP实现
- PHP四种排序算法实现及效率分析【冒泡排序,插入排序,选择排序和快速排序】
- 算法 -- iOS开发用Objective_C / Swift3.0实现:快速排序 / 冒泡排序 / 选择排序
- 几种常见排序算法之Java实现(插入排序、希尔排序、冒泡排序、快速排序、选择排序、归并排序)
- 快速排序,冒泡排序,直接选择排序的算法实现
- 冒泡排序、选择排序、堆排序、快速排序、插入排序算法复杂度分析与算法实现(自己总结与转)
- 快速排序的C#实现以及,算法导论上之后一个习题的思考
- 几种常用的排序算法:插入排序、冒泡排序、选择排序的算法及C++实现
- 数据结构与算法——三种基础排序算法C#实现(冒泡排序、选择排序、插入排序)
- 几种基本的排序算法(选择排序,冒泡排序,快速排序,归并排序,希尔排序)C语言实现
- 冒泡排序、选择排序、插入排序 算法实现(C++)
- 快速排序,冒泡排序,直接选择排序的算法
- Java分别实现冒泡排序、插入排序、快速排序、选择排序、交换排序
- C语言实现基本排序算法----排序(直接插入排序,SHELL排序,冒泡排序,快速排序,简单选择排序,堆排序)
- C#实现所有经典排序算法(选择排序,冒泡排序,快速排序,插入排序,希尔排序)
- [php] 数据结构&算法(PHP描述) 快速排序 quick sort