排序算法之冒泡算法
来源:互联网 发布:linux服务器系统命令 编辑:程序博客网 时间:2024/05/16 10:37
冒泡算法是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
function BubbleSort($array){
if (empty($array) || !is_array($array))
return false;
$len = count($array)-1;
for($i = $len; $i > 0; $i-- ){
for($j = 0; $j < $i; $j++){
if($array[$j+1] < $array[$j]){
$temp = $array[$j];
$array[$j] = $array[$j+1];
$array[$j+1] = $temp;
}
}
}
return $array;
}
时间复杂度:O(n*n)
冒泡算法改进方法一:
如果某一次循环中没有发生任何的交换,说明数据已经排好序了,直接跳出程序。
function BubbleSort2($array)
{
if (empty($array) || !is_array($array))
return false;
$len = count($array);
$ischange = false;
for($i = $len - 1 ;$i>0&&!$ischange;$i--)
{
$ischange = true;
for($j=0; $j < $i; $j++)
{
if($array[$j+1] < $array[$j])
{
$temp = $array[$j];
$array[$j] = $array[$j + 1];
$array[$j + 1] = $temp;
$ischange=false;
}
}
}
return $array;
}
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之 冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 算法之冒泡排序
- 2011年新篇90后"所谓黑客"名单
- 如何合并两个vector?
- POJ2425(树形,无向无环图博弈)
- win7里边使用telnet命令为什么提示telnet不是内部或外部命令,也不是可运行的程序或批处理文件?
- 大学毕业后拉开差距的真正原因
- 排序算法之冒泡算法
- Java异常处理总结 异常 详解~~
- 双链表
- struts2漏洞原理及解决办法
- Myeclipse/Eclipse 中修改默认字符编码
- PDF 开源库libharu
- vmlinux,vmlinuz,bzimage,zimage,initrd.img的区别与联系
- 讲整形int 16进制字符串输出
- 什么是多线程和与进程的比较