排序算法:七大排序算法的PHP实现
由于最近在找工作,面试中难免会遇到一些算法题,所以就用PHP把七大排序算法都实现了一遍,也当做是一种复习于沉淀。
- 冒泡排序 2. 选择排序 3. 插入排序 4. 快速排序 5. 希尔排序 6. 归并排序 7. 堆排序(较麻烦)
/**
* 冒泡排序
*/
function bubble($arr) {
$length = count($arr);
for ($i=1; $i<$length; ++$i) {
for ($j=0; $j < $length-$i; ++$j) {
if ($arr[$j] > $arr[$j+1]) {
$tmp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $tmp;
}
}
}
return $arr;
}
/**
* 选择排序
*/
function select($arr) {
$length = count($arr);
for ($i=0; $i<$length-1; ++$i) {
$minIndex = $i;
for ($j=$i+1; $j<$length; ++$j) {
if ($arr[$j] < $arr[$minIndex]) {
$minIndex = $j;
}
}
if ($minIndex != $i) {
$tmp = $arr[$minIndex];
$arr[$minIndex] = $arr[$i];
$arr[$i] = $tmp;
}
}
return $arr;
}
/**
* 插入排序
*/
function insert($arr) {
$length = count($arr);
for ($i=1; $i<$length; ++$i) {
$tmp = $arr[$i];
for ($j=$i-1; $j>=0; --$j) {
if ($tmp < $arr[$j]) {
$arr[$j+1] = $arr[$j];
$arr[$j] = $tmp;
} else {
break;
}
}
}
return $arr;
}
/**
* 快速排序
*/
function fast($arr) {
$length = count($arr);
if ($length < 1) {
return [];
}
$mid = $arr[0];
$left = [];
$right = [];
for ($i=1; $i<$length; ++$i) {
if ($arr[$i] < $mid) {
$left[] = $arr[$i];
} else {
$right[] = $arr[$i];
}
}
$sortLeft = fast($left);
$sortRight = fast($right);
return array_merge($sortLeft, [$mid], $sortRight);
}
/**
* 归并排序
*/
function merge($arr) {
$length = count($arr);
if ($length < 2) {
return $arr;
}
$left = [];
$right = [];
for ($i=0; $i<$length; ++$i) {
if ($i < $length/2) {
$left[] = $arr[$i];
} else {
$right[] = $arr[$i];
}
}
$left = merge($left);
$right = merge($right);
$merge = [];
while (count($left) > 0 && count($right) >0) {
if ($left[0] < $right[0]) {
$merge[] = array_shift($left);
} else {
$merge[] = array_shift($right);
}
}
if (count($left) > 0) {
$merge = array_merge($merge, $left);
} elseif (count($right) > 0) {
$merge = array_merge($merge, $right);
}
return $merge;
}
/**
* 希尔排序
*/
function shell($arr) {
$length = count($arr);
for ($gap = floor($length/2); $gap >0; $gap = floor($gap/2)) {
for ($i=$gap; $i<$length; $i += $gap) {
$tmp = $arr[$i];
for ($j=$i-$gap; $j>=0; $j -= $gap) {
if ($tmp < $arr[$j]) {
$arr[$j+$gap] = $arr[$j];
$arr[$j] = $tmp;
} else {
break;
}
}
}
echo $gap."\n";
}
return $arr;
}
/**
* 堆排序
*/
function heap($arr) {
$length = count($arr);
for ($i=floor($length/2)-1; $i>=0; --$i) {
$arr = adjustHeap($arr, $i, $length);
}
for ($i=$length-1; $i>=0; --$i) {
$tmp = $arr[0];
$arr[0] = $arr[$i];
$arr[$i] = $tmp;
$arr = adjustHeap($arr, 0, $i);
}
return $arr;
}
function adjustHeap($arr, $index, $length) {
$lchild = 2*$index+1;
$rchild = 2*$index+2;
$max = $index;
if ($index<=floor($length/2)-1) {
if ($lchild<$length && $arr[$lchild] > $arr[$max]) {
$max = $lchild;
}
if ($rchild<$length && $arr[$rchild] > $arr[$max]) {
$max = $rchild;
}
if ($max != $index) {
$tmp = $arr[$index];
$arr[$index] = $arr[$max];
$arr[$max] = $tmp;
$arr = adjustHeap($arr, $max, $length);
}
}
return $arr;
}
排序算法:七大排序算法的PHP实现的更多相关文章
- (转)白话经典算法系列之八 MoreWindows白话经典算法之七大排序总结篇
在我的博客对冒泡排序,直接插入排序,直接选择排序,希尔排序,归并排序,快速排序和堆排序这七种常用的排序方法进行了详细的讲解,并做成了电子书以供大家下载.下载地址为:http://download.cs ...
- 常见的七大排序算法Java实现
/** * @author Javen * @Email javenlife@126.com * 2015年12月9日 */ public class Sorting { static int[] a ...
- [C#][算法] 用菜鸟的思维学习算法 -- 马桶排序、冒泡排序和快速排序
用菜鸟的思维学习算法 -- 马桶排序.冒泡排序和快速排序 [博主]反骨仔 [来源]http://www.cnblogs.com/liqingwen/p/4994261.html 目录 马桶排序(令人 ...
- 算法与数据结构(十三) 冒泡排序、插入排序、希尔排序、选择排序(Swift3.0版)
本篇博客中的代码实现依然采用Swift3.0来实现.在前几篇博客连续的介绍了关于查找的相关内容, 大约包括线性数据结构的顺序查找.折半查找.插值查找.Fibonacci查找,还包括数结构的二叉排序树以 ...
- javascript数据结构与算法--高级排序算法
javascript数据结构与算法--高级排序算法 高级排序算法是处理大型数据集的最高效排序算法,它是处理的数据集可以达到上百万个元素,而不仅仅是几百个或者几千个.现在我们来学习下2种高级排序算法-- ...
- javascript数据结构与算法--基本排序算法分析
javascript中的基本排序算法 对计算机中存储的数据执行的两种最常见操作是排序和检索,排序和检索算法对于前端开发尤其重要,对此我会对这两种算法做深入的研究,而不会和书上一样只是会贴代码而已,下面 ...
- 必须知道的八大种排序算法【java实现】(三) 归并排序算法、堆排序算法详解
一.归并排序算法 基本思想: 归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的.然后再把有序子序列合并为整体有序序列. 归并 ...
- 线性时间的排序算法--桶排序(以leetcode164. Maximum Gap为例讲解)
前言 在比较排序的算法中,快速排序的性能最佳,时间复杂度是O(N*logN).因此,在使用比较排序时,时间复杂度的下限就是O(N*logN).而桶排序的时间复杂度是O(N+C),因为它的实现并不是基于 ...
- Stooge排序与Bogo排序算法
本文地址:http://www.cnblogs.com/archimedes/p/stooge-bogo-sort-algorithm.html,转载请注明源地址. Stooge排序算法 Stooge ...
随机推荐
- 李洪强iOS开发之零基础学习iOS开发】【02-C语言】01-概述
前面已经给大家介绍了iOS开发相关的一些基础知识,其实iOS开发就是开发iPhone\iPad上的软件,而要想开发一款软件,首先要学习程序设计语言.iOS开发需要学习的主要程序设计语言有:C语言.C+ ...
- 快速学习bootstrap前台框架
W3c里的解释 使用bootstrap需要注意事项 1. 在html文件第一行要加上<!doctype html>[s1] 2. 导入bootstrap.min.css文件 3. 导 ...
- asp.net中当服务器出错时显示指定的错误页面
http://blog.csdn.net/helloxiaoyu/article/details/2943537 此篇文章描述了当异常再ASP.NET中发生时怎样使用C#.NET代码去拦截和相应异常. ...
- java @param参数注解
注解,@param是参数的解释.如/***@param s 这里表示对s的文字说明,描述 */ public void aa(String s){}一般java中@表示注解,解释一个方法,类,属性的作 ...
- 3.Spring-用反射模拟IoC
1.BeanFactory.java package com.jike.spring.chapter03.reflect; import java.io.InputStream; import jav ...
- public View getView(int position, View convertView, final ViewGroup parent)三个参数的意思
最近看到有人在问这三个参数的含义,其实帮助已经很详细的介绍了这三个参数,看来还是要好好学学英语了,不然连解释都看不懂. /** * Get a View that displays the d ...
- 关于Javascript函数的几点笔记
函数本质上是一个有名字的程序块,程序块使得多条语句可以一起执行. 变量类型: 1.复杂类型:Object.Array等. 2.原始类型:String.Integer等. 函数参数: 1.复杂类型:传递 ...
- MATLAB曲线绘制
一. 二维数据曲线图1.1 绘制 单根二维曲线plot 函数的基本调用 格式为:plot(x,y) 其中x和y为长度相同的向量,分别用于存储x坐标 和y坐标数据. 例1-1 在0≤x≤2p区间内,绘制 ...
- weblogic11g 安装集群 —— win2003 系统、单台主机
weblogic11g 安装集群 —— win2003 系统.单台主机 注意:此为weblogic11g 在win2003系统下(一台主机)的安装集群,linux.hpux.aix及多个主机下原理一 ...
- jquery学习以及下载链接
jquery学习链接 http://www.w3school.com.cn/jquery/jquery_intro.asp jquery 脚本库下载链接 http://jquery.com/downl ...