1、直接插入排序
/* * 直接插入排序,插入排序的思想是:当前插入位置之前的元素有序, * 若插入当前位置的元素比有序元素最后一个元素大,则什么也不做, * 否则在有序序列中找到插入的位置,并插入 */function insertsort($arr) { $len = count($arr); for($i = 1; $i $arr[i]) { for($j = $i - 1;$j >= 0; $j-- ) { $tmp = $arr[$j+1]; if($tmp < $arr[$j]) { $arr[$j+1] = $arr[$j]; $arr[$j] = $tmp; }else{ break; } } } } return $arr;}
2、冒泡排序
/* 冒泡排序,冒泡排序思想:进行 n-1 趟冒泡排序, 每趟两两比较调整最大值到数组(子数组)末尾*/function bubblesort($arr) { $len = count($arr); for($i = 1; $i < $len; $i++) { for($j = 0; $j $arr[$j+1]) { $tmp = $arr[$j+1]; $arr[$j+1] = $arr[$j]; $arr[$j] = $tmp; } } } return $arr;}
3、简单选择排序
/* 简单选择排序, 简单排序思想:从数组第一个元素开始依次确定从小到大的元素*/function selectsort($arr) { $len = count($arr); for($i = 0; $i 0) { for($i = 0; $i < $k; $i++) { for($j = $i; $j < $len, ($j + $k) $arr[$j+$k]) { $tmp = $arr[$j+$k]; $arr[$j+$k] = $arr[$j]; $arr[$j] = $tmp; } } } $k = floor($k/2); } return $arr;}
5、快速排序
/* * 快速排序,快排思想:通过一趟排序将待排的记录分为两个独立的部分,其中一部分的记录的关键字均不大于 * 另一部分记录的关键字,然后再分别对这两部分记录继续进行快速排序,以达到整个序列有序,具体做法需要 * 每趟排序设置一个标准关键字和分别指向头一个记录的关键字和最后一个记录的关键字的指针。 * quicksort($arr, 0, count($arr) -1); */function quicksort(&$arr,$low,$high) { if($low < $high) { $i = $low; $j = $high; $primary = $arr[$low]; while($i < $j) { while($i = $primary) { $j--; } if($i < $j) { $arr[$i++] = $arr[$j]; } while($i < $j && $arr[$i] <= $primary) { $i++; } if($i < $j) { $arr[$j--] = $arr[$i]; } } $arr[$i] = $primary; quicksort($arr, $low, $i-1); quicksort($arr, $i+1, $high); }}
6、堆排序
/* 堆排序*/// 调整子堆的为大根堆的过程,$s为子堆的根的位置,$m为堆最后一个元素位置function heapadjust(&$arr, $s, $m) { $tmp = $arr[$s]; // 在调整为大根堆的过程中可能会影响左子堆或右子堆 // for循环的作用是要保证子堆也是大根堆 for($j = 2*$s + 1; $j 0; $n--) { $tmp = $arr[$n]; $arr[$n] = $arr[0]; $arr[0] = $tmp; heapadjust($arr, 0, $n-1); } return $arr;}
7、归并排序
/* 归并排序,这里实现的是两路归并*/// 分别将有序的$arr1[s..m]、$arr2[m+1..n]归并为有序的$arr2[s..n]function merge(&$arr1, &$arr2, $s, $m, $n) { for($k = $s,$i = $s, $j = $m+1; $i <= $m && $j <= $n; $k++) { if($arr1[$i]<$arr1[$j]) { $arr2[$k] = $arr1[$i++]; }else { $arr2[$k] = $arr1[$j++]; } } if($i <= $m) { for(; $i <= $m; $i++) { $arr2[$k++] = $arr1[$i]; } } else if($j <= $n) { for(; $j <= $n; $j++) { $arr2[$k++] = $arr1[$j]; } }}// 递归形式的两路归并function msort(&$arr1, &$arr2, $s, $t) { if($s == $t) { $arr2[$s] = $arr1[$s]; }else { $m = floor(($s+$t)/2); $tmp_arr = array(); msort($arr1, $tmp_arr, $s, $m); msort($arr1, $tmp_arr, $m+1, $t); merge($tmp_arr, $arr2, $s, $m, $t); }}// 对一位数组$arr[0..n-1]中的元素进行两路归并function mergesort($arr) { $len = count($arr); msort($arr, $arr, 0, $len-1); return $arr;}
使用经验
若排序的记录数目n较小时,可以采用直接插入排序和简单选择排序,当记录本身信息量较大时,用简单选择排序方法较好。
若待排序记录按关键字基本有序,适合采用直接插入排序和冒泡排序。
若n值较大时,可以采用快速排序、堆排序和归并排序。另外快速排序被认为是内部排序方法中最好的方法。
以上就是本文的全部内容,希望对大家的学习有所帮助。
您可能感兴趣的文章:php 数组排序方法总结 推荐收藏php 多维数组的排序问题 根据二维数组中某个项排序php 冒泡排序 二分查找 顺序查找 二维数组排序算法函数的详解php二维数组排序详解php二维数组排序方法(array_multisort usort)php实现快速排序的三种方法分享php二维数组排序的3种方法和自定义函数分享php数组中包含中文的排序方法php中的排序函数sort、asort、rsort、krsort、ksort区别分析php中多维数组按指定value排序的实现代码
http://www.bkjia.com/phpjc/1110082.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/1110082.htmltecharticle7种php基本排序实现方法,7种php排序 本文总结了一下常用的7种排序方法,并用php语言实现。 1、直接插入排序 /* * 直接插入排序,插入排序的...
