PHP 冒泡排序算法的实现代码


Posted in PHP onAugust 08, 2010

基本概念

冒泡排序的基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即首先比较第1 个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,如此继续,直至比较最后两个数,将小数放前,大数放后。重复以上过程,仍从第一对数开始比较(因为可能由于第2个数和第3个数的交换,使得第1个数不再大于第2个数),将小数放前,大数放后,一直比较到最小数前的一对相邻数,将小数放前,大数放后,第二趟结束,在倒数第二个数中得到一个新的最小数。如此下去,直至最终完成排序。
由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序。
用二重循环实现,外循环变量设为i,内循环变量设为j。外循环重复9次,内循环依次重复 9,8,…,1次。每次进行比较的两个元素都是与内循环j有关的,它们可以分别用a[j]和a[j+1]标识,i的值依次为1,2,…,9,对于每一个i, j的值依次为1,2,…10-i。

产生
在许多程序设计中,我们需要将一个数列进行排序,以方便统计,常见的排序方法有冒泡排序,二叉树排序,选择排序等等。而冒泡排序一直由于其简洁的思想方法和比较高的效率而倍受青睐。

排序过程
设想被排序的数组R[1..N]垂直竖立,将每个数据元素看作有重量的气泡,根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R,凡扫描到违反本原则的轻气泡,就使其向上”漂浮”,如此反复进行,直至最后任何两个气泡都是轻者在上,重者在下为止。

Update 2009-8-18: 更新代码的错误。

$arr = array(345,4,17,6,52,16,58,69,32,8,234); 
for($i=1;$i<count($arr);$i++){ 
for($j=count($arr)-1;$j>=$i;$j--){ 
if($arr[$j]<$arr[$j-1]){ 
$temp = $arr[$j-1]; 
$arr[$j-1] = $arr[$j]; 
$arr[$j] = $temp; 
} 
} 
}

请使用PHP实现冒泡排序,将数组$a = array()按照从小到大的方式进行排序

$a=array('3','8','1','4','11','7'); 
 print_r($a); 
 echo '<br/>'; 
 $len=count($a); 
 //从小到大 
 for($i=1;$i<$len;$i++){ 
 for($j=$len-1;$j>=$i;$j--){ 
 if($a[$j]<$a[$j-1]){ 
 $x=$a[$j];
  $a[$j]=$a[$j-1]; 
 $a[$j-1]=$x; 
 } 
} 
}

PHP 简单实现冒泡排序

学习PHP的时候不敢往算法上靠近。就是怕扰乱自己的思想,现在回顾一下也还真的就那一回事。嘿嘿!各位有没有遇到这样子的情况呢?

<?php
#冒泡排序法
$arr = array(12,45,89,3,24,55,223,76,22,11,89,2,4,5,28,112,20,434,23,65,65,765,6,8,23,5,33,553,45,423,64,77,84,23);
$tmp;
for($i=0;$i<count($arr)-1;$i++ ){    
  for($j=0;$j<count($arr)-1-$i;$j++){ 
    if($arr[$j] > $arr[$j+1]){
      $tmp = $arr[$j];
      $arr[$j] = $arr[$j+1];
      $arr[$j+1] = $tmp;
    } 
  }
} 
print_r($arr);

php冒泡排序

$b=array('4','3','8','9','2','1');
$len=count($b);//6

第一种:

for($k=0;$k<=$len;$k++)
{
  for($j=$len-1;$j>$k;$j--){
    if($b[$j]<$b[$j-1]){
      $temp = $b[$j];
      $b[$j] = $b[$j-1];
      $b[$j-1] = $temp;
    }
  }
}

第二种:

for($k=1;$k<$len;$k++)
{
  for($j=0;$j<$len-$k;$j++){
    if($b[$j]>$b[$j+1]){
      $temp =$b[$j+1];
      $b[$j+1] =$b[$j] ;
      $b[$j] = $temp;
    }
  }
}
PHP 相关文章推荐
php快速url重写更新版[需php 5.30以上]
Apr 25 PHP
检测png图片是否完整的php代码
Sep 06 PHP
PHP中通过加号合并数组的一个简单方法分享
Jan 27 PHP
PHP curl_setopt()函数实例代码与参数分析
Jun 02 PHP
PHP set_error_handler()函数使用详解(示例)
Nov 12 PHP
php-redis中的sort排序函数总结
Jul 08 PHP
给WordPress中的留言加上楼层号的PHP代码实例
Dec 14 PHP
php array_pop 删除数组最后一个元素实例
Nov 02 PHP
PHP实现基于栈的后缀表达式求值功能
Nov 10 PHP
php 截取中英文混合字符串的方法
May 31 PHP
Yii 框架控制器创建使用及控制器响应操作示例
Oct 14 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
Feb 27 PHP
php下关于Cannot use a scalar value as an array的解决办法
Aug 08 #PHP
在PHP中实现Javascript的escape()函数代码
Aug 08 #PHP
PHP下escape解码函数的实现方法
Aug 08 #PHP
ubuntu 编译安装php 5.3.3+memcache的方法
Aug 05 #PHP
PHP MemCached高级缓存配置图文教程
Aug 05 #PHP
PHP Array交叉表实现代码
Aug 05 #PHP
php垃圾代码优化操作代码
Aug 05 #PHP
You might like
用PHP连接Oracle for NT 远程数据库
2006/10/09 PHP
php+mysql开源XNA 聚合程序发布 下载
2007/07/13 PHP
PHP 内存缓存加速功能memcached安装与用法
2009/09/03 PHP
Session保存到数据库的php类分享
2011/10/24 PHP
不使用php api函数实现数组的交换排序示例
2014/04/13 PHP
php面向对象中static静态属性与方法的内存位置分析
2015/02/08 PHP
jquery select(列表)的操作(取值/赋值)
2009/08/06 Javascript
jQuery学习2 选择器的使用说明
2010/02/07 Javascript
jQuery load方法用法集锦
2011/12/06 Javascript
tangram框架响应式加载图片方法
2013/11/21 Javascript
js使用removeChild方法动态删除div元素
2014/08/01 Javascript
XML文件转化成NSData对象的方法
2015/08/12 Javascript
关于JS中setTimeout()无法调用带参函数问题的解决方法
2016/06/21 Javascript
基于原生js运动方式关键点的总结(推荐)
2017/10/01 Javascript
微信小程序时间控件picker view使用详解
2018/12/28 Javascript
[51:26]DOTA2上海特级锦标赛主赛事日 - 2 胜者组第一轮#3Secret VS OG第二局
2016/03/03 DOTA
pyv8学习python和javascript变量进行交互
2013/12/04 Python
python访问sqlserver示例
2014/02/10 Python
Python爬虫设置代理IP的方法(爬虫技巧)
2018/03/04 Python
python pandas 如何替换某列的一个值
2018/06/09 Python
浅谈python在提示符下使用open打开文件失败的原因及解决方法
2018/11/30 Python
Python利用heapq实现一个优先级队列的方法
2019/02/03 Python
Python3调用百度AI识别图片中的文字功能示例【测试可用】
2019/03/13 Python
Python代理IP爬虫的新手使用教程
2019/09/05 Python
python Socket网络编程实现C/S模式和P2P
2020/06/22 Python
解决keras使用cov1D函数的输入问题
2020/06/29 Python
python smtplib发送多个email联系人的实现
2020/10/09 Python
Python 实现RSA加解密文本文件
2020/12/30 Python
最新英语专业学生求职信范文
2013/09/21 职场文书
简历中的自我评价怎么写
2014/01/29 职场文书
市场营销专业自荐书
2014/06/10 职场文书
城市规划应届毕业生自荐信
2014/07/04 职场文书
大学毕业生推荐信
2014/07/09 职场文书
2014年财务工作总结与计划
2014/12/08 职场文书
js实现模拟购物商城案例
2021/05/18 Javascript
CSS Transition通过改变Height实现展开收起元素
2021/08/07 HTML / CSS