PHP实现冒泡排序、双向冒泡排序算法
冒泡排序(Bubble Sort),是一种较简单的、稳定的排序算法。冒泡排序算法步骤:比较相邻的元素,如果第一个比第二个大,就交换他们两个的位置;对每对相邻的元素执行同样的操作,这样一趟下来,最后的元素就是最大的;除了已得出来的最大元素,把剩余的元素重复前面步骤,直到没有元素再需要比较为止,这样排序就完成了。冒泡算法,在最好情况下,时间复杂度为O(n);在最坏情况下,时间复杂度为O(n2);平均时间复杂度为O(n2)。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
|
<?php/** * 数据结构与算法(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>' ;?> |
PHP实现冒泡排序、双向冒泡排序算法的更多相关文章
- Problem D: 双向冒泡排序
Problem D: 双向冒泡排序 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 447 Solved: 197[Submit][Status][We ...
- python 排序冒泡排序与双向冒泡排序
冒泡排序: 冒泡排序就是每次找出最大(最小)元素,放在集合最前或最后,这是最简单的排序算法 def bubble_sort(collection): #升序排列 length=len(collecti ...
- PHP描述冒泡排序和快速排序算法
使用PHP描述冒泡排序和快速排序算法,对象可以是一个数组.使用PHP描述顺序查找和二分查找(也叫做折半查找)算法,顺序查找必须考虑效率,对象可以是一个有序数组.写一个二维数组排序算法函数,能够具有通用 ...
- Java - 冒泡排序的基础算法(尚学堂第七章数组)
/** * 冒泡排序的基础算法 */ import java.util.Arrays; public class TestBubbleSort1 { public static void main(S ...
- Qt 5.11的QChar、QString、QTextBoundaryFinder和双向文本算法现在完全兼容Unicode 10
本文翻译自:Qt 5.11 released 原文作者: Qt公司CTO兼Qt开源项目维护官Lars Knoll翻译校审:Richard.Hongfei.Haipeng 5月22日,我们提发布了Qt ...
- C++实现双向RRT算法
C++实现双向RRT算法 背景介绍 RRT(Rapidly-exploring Random Trees)是Steven M. LaValle和James J. Kuffner Jr.提出的一种通过所 ...
- [6] 算法路 - 双向冒泡排序的Shaker
Shaker序列 –算法 1. 气泡排序的双向进行,先让气泡排序由左向右进行.再来让气泡排序由右往左进行,如此完毕一次排序的动作 2. 使用left与right两个旗标来记录左右两端已排序的元素位置. ...
- java基础 - 冒泡排序,随机数算法
从简单做起 任何困难的事情都是由简单的一步步一件件事情堆起来 理解好算法才是最重要 1.冒泡排序: public class Test { public static void main(String ...
- 排序系列 之 冒泡排序及其改进算法 —— Java实现
冒泡排序算法 冒泡排序算法 改进一 冒泡排序算法 改进二 冒泡排序算法 改进三 冒泡排序算法 基本思想: 在要排序的一组数中,对当前还未排好序的范围内的全部数据,自上而下对相邻的两个数依次进行比较和调 ...
随机推荐
- Effective C++_笔记_条款01_视C++为一个语言联邦
(整理自Effctive C++,转载请注明.整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/) C++的各种能力和特性使它成为一个无可匹敌的工具,但也可能引发某 ...
- 表likp新增第一次过账输入日期字段,vl02n/vl01n/vl03n/vl06o的增强
在程序:MV50AFZ1的 FORM USEREXIT_SAVE_DOCUMENT_PREPARE. *begin of ADD CRQ000000012135 CAIZJIAN 2014/3/25( ...
- QNX---- interrupts 例程
#include <sys/neutrino.h> int interruptID; const struct sigevent * intHandler (void *arg, int ...
- SuperSocket应用之FTP源码解析
一 简述 命令行协议是一种使用比较多的协议,其优点在于使用简单易于扩展性,同时也利于解析和使用.FTP,POP,SMTP等均采用命令行协议,其中FTP在早起互联网时期成为网络资源共享的主要方式,可见F ...
- Mybatis 数据库物理分页插件 PageHelper
以前使用ibatis/mybatis,都是自己手写sql语句进行物理分页,虽然稍微有点麻烦,但是都习惯了.最近试用了下mybatis的分页插件 PageHelper,感觉还不错吧.记录下其使用方法. ...
- 基于visual Studio2013解决面试题之0401非递归遍历二叉树
题目
- SqlHelper初探之二
在上一篇简单的介绍了sqlhelper的基本知识,接下来就让我们进一步学习他的实践过程. 首先:我们要明白的一件事Sqlhelper不是写出来的,而是在D层的代码中提炼出来的?那么就会反问一句“D层中 ...
- Swift - 九宫格图片缩放总结样例
1,图片左中右三宫格缩放形式 //左右14像素不变形,中间缩放 let imgTrackRight = UIImage(named:"slider_max") let imgRig ...
- .Net 配置文件——继承ConfigurationSection实现自己定义处理类处理自己定义配置节点
除了使用继承IConfigurationSectionHandler的方法定义处理自己定义节点的类.还能够通过继承ConfigurationSection类实现相同效果. 首先说下.Net配置文件里一 ...
- NET Platform Standard
NET Platform Standard 相关博文:ASP.NET 5 Target framework dnx451 and dnxcore50 .NET Platform Standard:ht ...