PHP实现各种排序算法
2015-05-13 21:59
323 查看
PHP实现各种排序算法
http://www.open-open.com/lib/view/open1399815575207.htmls// 冒泡排序
function BubbleSort($arr) {
// 获得数组总长度
$num = count($arr);
// 正向遍历数组
for ($i = 1; $i < $num; $i++) {
//
反向遍历
for ($j = $num - 1; $j >= $i ; $j--) {
//
相邻两个数比较
if ($arr[$j] < $arr[$j-1]) {
//
暂存较小的数
$iTemp = $arr[$j-1];
//
把较大的放前面
$arr[$j-1] = $arr[$j];
//
较小的放后面
$arr[$j] = $iTemp;
}
}
}
return $arr;
}
// 交换法排序
function ExchangeSort($arr){
$num = count($arr);
// 遍历数组
for ($i = 0;$i < $num - 1; $i++) {
//
获得当前索引的下一个索引
for ($j = $i + 1; $j < $num; $j++) {
//
比较相邻两个的值大小
if ($arr[$j] < $arr[$i]) {
//
暂存较小的数
$iTemp = $arr[$i];
//
把较大的放前面
$arr[$i] = $arr[$j];
//
较小的放后面
$arr[$j] = $iTemp;
}
}
}
return $arr;
}
// 选择法排序
function SelectSort($arr) {
// 获得数组总长度
$num = count($arr);
// 遍历数组
for ($i = 0;$i < $num-1; $i++) {
//
暂存当前值
$iTemp = $arr[$i];
//
暂存当前位置
$iPos = $i;
//
遍历当前位置以后的数据
for ($j = $i + 1;$j < $num; $j++){
//
如果有小于当前值的
if ($arr[$j] < $iTemp) {
//
暂存最小值
$iTemp = $arr[$j];
//
暂存位置
$iPos = $j;
}
}
//
把当前值放到算好的位置
$arr[$iPos] = $arr[$i];
//
把当前值换成算好的值
$arr[$i] = $iTemp;
}
return $arr;
}
// 插入法排序
function InsertSort($arr){
$num = count($arr);
// 遍历数组
for ($i = 1;$i < $num; $i++) {
//
获得当前值
$iTemp = $arr[$i];
//
获得当前值的前一个位置
$iPos = $i - 1;
//
如果当前值小于前一个值切未到数组开始位置
while (($iPos >= 0) && ($iTemp < $arr[$iPos])) {
//
把前一个的值往后放一位
$arr[$iPos + 1] = $arr[$iPos];
//
位置递减
$iPos--;
}
$arr[$iPos+1] = $iTemp;
}
return $arr;
}
// 快速排序
function QuickSort($arr){
$num = count($arr);
$l = $r = 0;
// 从索引的第二个开始遍历数组
for ($i = 1;$i < $num; $i++) {
//
如果值小于索引1
if ($arr[$i] < $arr[0]) {
//
装入左索引数组(小于索引1的数据)
$left[] = $arr[$i];
$l++;
} else {
//
否则装入右索引中(大于索引1的数据)
$right[] = $arr[$i];
$r++; //
}
}
// 如果左索引有值
则对左索引排序
if($l > 1) {
$left = QuickSort($left);
}
// 排序后的数组
$new_arr = $left;
// 将当前数组第一个放到最后
$new_arr[] = $arr[0];
// 如果又索引有值
则对右索引排序
if ($r > 1) {
$right = QuickSort($right);
}
// 根据右索引的长度再次增加数据
for($i = 0;$i < $r; $i++) {
$new_arr[] = $right[$i];
}
return $new_arr;
}
?>
相关文章推荐
- PHP实现各种排序算法
- PHP实现各种排序算法
- 用php实现的各种排序算法总结
- 用php实现的各种排序算法总结
- PHP 各种排序算法实现代码
- PHP 各种排序算法实现代码
- PHP实现各种经典算法 ||
- 2.顺序表实现与各种排序算法
- C语言实现各种排序算法
- PHP 排序算法的实现
- 排序原始数据[置顶] 各种常见排序算法实现
- 各种排序算法的讲解与代码实现
- 各种排序算法的实现及其比较
- python实现的各种排序算法代码
- 数组游标实现对数组的各种操作(PHP学习)
- 各种基本算法实现小结(五)—— 排序算法
- 用 python 实现各种排序算法(转)
- 常用的各种排序算法的JAVA实现
- 各种排序算法的分析及java实现
- 各种排序算法的C++实现