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 相关文章推荐
怎样在UNIX系统下安装php3
Oct 09 PHP
php session_start()关于Cannot send session cache limiter - headers already sent错误解决方法
Nov 27 PHP
php file_put_contents()功能函数(集成了fopen、fwrite、fclose)
May 24 PHP
PHP--用万网的接口实现域名查询功能
Dec 13 PHP
php实现文件下载实例分享
Jun 02 PHP
PHP使用Alexa API获取网站的Alexa排名例子
Jun 12 PHP
php函数实现判断是否移动端访问
Mar 03 PHP
PHP调用.NET的WebService 简单实例
Mar 27 PHP
php关键字仅替换一次的实现函数
Oct 29 PHP
Laravel (Lumen) 解决JWT-Auth刷新token的问题
Oct 24 PHP
php 中self,this的区别和操作方法实例分析
Nov 04 PHP
用php如何解决大文件分片上传问题
Jul 07 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中的数组操作函数整理
2008/08/18 PHP
用PHP代替JS玩转DOM的思路及示例代码
2014/06/15 PHP
php简单获取目录列表的方法
2015/03/24 PHP
thinkPHP中多维数组的遍历方法
2016/01/09 PHP
PHP使用DOM和simplexml读取xml文档的方法示例
2017/02/08 PHP
JavaScript获取GridView选择的行内容
2009/04/14 Javascript
javascript中with()方法的语法格式及使用
2014/08/04 Javascript
js判断手机和pc端选择不同执行事件的方法
2015/01/30 Javascript
canvas实现绘制吃豆鱼效果
2017/01/12 Javascript
js鼠标移动时禁止选中文字
2017/02/19 Javascript
jquery版轮播图效果和extend扩展
2017/07/18 jQuery
微信上传视频文件提示(推荐)
2018/11/22 Javascript
JS原型和原型链原理与用法实例详解
2020/02/05 Javascript
python 中文乱码问题深入分析
2011/03/13 Python
简单的Apache+FastCGI+Django配置指南
2015/07/22 Python
Python解析excel文件存入sqlite数据库的方法
2016/11/15 Python
python GUI库图形界面开发之pyinstaller打包python程序为exe安装文件
2020/02/26 Python
Pycharm中切换pytorch的环境和配置的教程详解
2020/03/13 Python
python实现批处理文件
2020/07/28 Python
挪威太阳镜和眼镜网上商城:SmartBuyGlasses挪威
2016/08/20 全球购物
英国最大的汽车配件在线商店:Euro Car Parts
2019/09/30 全球购物
软件测试工程师结构化面试题库
2016/11/23 面试题
化工专业推荐信范文
2013/11/28 职场文书
马云的职业生涯规划之路
2014/01/01 职场文书
结婚典礼证婚词
2014/01/11 职场文书
公司薪酬管理制度
2014/01/31 职场文书
新年抽奖获奖感言
2014/03/02 职场文书
小学综治宣传月活动总结
2014/07/02 职场文书
党的群众路线教育实践活动心得体会(企业)
2014/11/03 职场文书
会议开幕词
2015/01/28 职场文书
2015年安全生产月活动总结
2015/03/26 职场文书
2015年打非治违工作总结
2015/04/02 职场文书
医务人员医德医风心得体会
2016/01/25 职场文书
Mac电脑OS系统下安装Nginx的详细教程
2022/04/14 Servers
python实现简单的三子棋游戏
2022/04/28 Python
win10系统xps文件怎么打开?win10打开xps文件的两种操作方法
2022/07/23 数码科技