2014-09-05
冒泡排序(Bubble Sort),是一种较简单的、稳定的排序算法。冒泡排序算法步骤:比较相邻的元素,如果第一个比第二个大,就交换他们两个的位置;对每对相邻的元素执行同样的操作,这样一趟下来,最后的元素就是最大的;除了已得出来的最大元素,把剩余的元素重复前面步骤,直到没有元素再需要比较为止,这样排序就完成了。冒泡算法,在最好情况下,时间复杂度为O(n);在最坏情况下,时间复杂度为O(n2);平均时间复杂度为O(n2)。
PHP实现冒泡排序、双向冒泡排序算法 1
/**
* 数据结构与算法(PHP实现) - 冒泡排序(Bubble Sort)。
*
* @author 创想编程(TOPPHP.ORG)
* @copyright Copyright (c) 2013 创想编程(TOPPHP.ORG) All Rights Reserved
* @license http://www.opensource.org/licenses/mit-license.php MIT LICENSE
* @version 1.0.0 - Build20130608
*/
class BubbleSort {
/**
* 冒泡排序。
*
* @var integer
*/
const SORT_NORMAL = 1;
/**
* 双向冒泡排序。
*
* @var integer
*/
const SORT_DUPLEX = 2;
/**
* 需要排序的数据数组。
*
* @var array
*/
private $data;
/**
* 数据数组的长度。
*
* @var integer
*/
private $size;
/**
* 数据数组是否已排序。
*
* @var boolean
*/
private $done;
/**
* 构造方法 - 初始化数据。
*
* @param array $data 需要排序的数据数组。
*/
public function __construct(array $data) {
$this->data = $data;
$this->size = count($this->data);
$this->done = FALSE;
}
/**
* 交换数据数组中两个元素的位置。
*
* @param integer $x 元素在数组中的索引。
* @param integer $y 元素在数组中的索引。
*/
private function swap($x, $y) {
$temp = $this->data[$x];
$this->data[$x] = $this->data[$y];
$this->data[$y] = $temp;
}
/**
* 冒泡排序。
*/
private function sort() {
$this->done = TRUE;
for ($i = 1; $i < $this->size; ++$i) {
// 记录交换数据的次数。
$swap = 0;
for ($j = $this->size - 1; $j > $i - 1; --$j) {
if ($this->data[$j] < $this->data[$j - 1]) {
$this->swap($j - 1, $j);
++$swap;
}
}
// 若交换数据的次数为0,说明数据数组已有序,不必再进行排序。
if (0 === $swap) {
break ;
}
}
}
/**
* 双向冒泡排序。
*/
private function duplexSort() {
$this->done = TRUE;
for ($i = 1; $i <= floor($this->size / 2); ++$i) {
// 记录交换数据的次数。
$swap = 0;
for ($j = $this->size - 1, $k = $i - 1;
$j > $i - 1 && $k < $this->size - 1; --$j, ++$k) {
if ($this->data[$j] < $this->data[$j - 1]) {
$this->swap($j - 1, $j);
++$swap;
}
if ($this->data[$k] > $this->data[$k + 1]) {
$this->swap($k, $k + 1);
++$swap;
}
}
// 若交换数据的次数为0,说明数据数组已有序,不必再进行排序。
if (0 === $swap) {
break;
}
}
}
/**
* 获取排序后的数据数组。
*
* @param integer $sort 排序算法:SORT_NORMAL为冒泡排序;SORT_DUPLEX为双向冒泡排序。
* @return array 返回排序后的数据数组。
*/
public function getResult($sort = self::SORT_NORMAL) {
// 若已排序则无需再进行排序,直接返回排序好的数据数组。
if ($this->done) {
return $this->data;
}
switch ($sort) {
case self::SORT_DUPLEX:
$this->duplexSort();
break;
case self::SORT_NORMAL:
default:
$this->sort();
break;
}
return $this->data;
}
}
?>
示例代码 1
2
3
4 <?php
$bubble = new BubbleSort(array(35, 75, 92, 41, 27, 58));
echo '<pre>', print_r($bubble->getResult(BubbleSort::SORT_DUPLEX), TRUE), '</pre>';
?>
1
CI框架连接数据库配置操作以及多数据库操作
09-05
2
asp 简单读取数据表并列出来 ASP如何快速从数据库读取大量数据
05-17
3
C语言关键字及其解释介绍 C语言32个关键字详解
04-05
4
C语言中sizeof是什么意思 c语言里sizeof怎样用法详解
04-26
5
最简单的asp登陆界面代码 asp登陆界面源代码详细介绍
04-12
6
PHP中的魔术方法 :__construct, __destruct , __call, __callStatic,__get, __set, __isset, __unset , __sleep,
09-05
7
PHP中的(++i)前缀自增 和 (i++)后缀自增
09-05
8
PHP中include和require区别之我见
09-05
常用dos命令及语法
2014-09-27
将视频设置为Android手机开机动画的教程
2014-12-11
php递归返回值的问题
2014-09-05
如何安装PHPstorm并配置方法教程 phpstorm安装后要进行哪些配置
2017-05-03
java中的info是什么意思
2022-03-24
PHP 教程之如何使用BLOB存取图片信息实例
2014-09-05
IcePHP框架中的快速后台中的通用CRUD功能框架
2014-09-05
单片机编程好学吗?单片机初学者怎样看懂代码
2022-03-21
PHP数组函数array
2014-09-05
学ug编程如何快速入门?
2022-03-17
原始征途九游版下载v1.0.95 安卓版
动作闯关 404.9M
下载龙族卡塞尔之门手游下载v1.3.1 安卓版
卡牌对战 734.0M
下载爆炒江湖官服下载v1.43 安卓版
角色扮演 842.8M
下载宝宝学abc宝宝巴士游戏下载v10.00.24.11 安卓官方版
其它手游 171.1M
下载奇妙商场嘉年华最新版本(改名奇妙故事创造家)下载v9.87.58.00 安卓版
其它手游 221.1M
下载最佳球会九游版下载v2.5.161 安卓官方版
经营养成 1.87G
下载热血传奇跨服新大陆官方手游下载v1.9.134.15150 安卓最新版本
角色扮演 1.50G
下载波比的游戏时间第四章玩家自制版(PlaytimeStarterKit)下载v9.1 安卓版
其它手游 1.14G
下载方块枪战block gun游戏下载v9.8 安卓版
下载
zepeto中文版(更名崽崽ZEPETO)下载v4.2.210 安卓版
下载
现代战舰手游下载v0.94.3.120515958 安卓手机版
下载
Modern Warships现代战舰国际服官方正版下载v0.94.3.120515958 安卓最新版
下载
2025指尖捕鱼新版下载v10.2.44.7.0 安卓正版
下载
指尖捕鱼赢话费版下载v10.2.44.7.0 安卓版
下载
指尖捕鱼高爆率多人捕鱼游戏下载v10.2.44.7.0 安卓版
下载
指尖捕鱼吴孟达版下载v10.2.44.7.0 安卓最新版
下载