很基础的东西,感觉代码还不够简洁,希望高手指导修改
复制代码 代码如下:
function BubbleSort($str){
for($i=0;$i
if($str[$k+1]$tmp=$str[$k+1];
$str[$k+1]=$str[$k];
$str[$k]=$tmp;
}
}
}
return $str;
}
//以下是测试
$str=array(5,8,2,6,10,0,3,12,11);
print_r(BubbleSort($str));
?>
php 冒泡排序2
基本概念是:依次比较相邻的两个数,将小数放在前面,大数放在后面。即首先比较第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。
复制代码 代码如下:
function asc($a)
{
for($i=0;$i
for($j=0;$j
if($a[$j]>$a[$j+1])
{
$tmp=$a[$j+1];
$a[$j+1]=$a[$j];
$a[$j]=$tmp;
}
}
}
print_r($a);
}
$a = array(9,8,17,6,26,4,33,2,1);
print_r(asc($a));
?>
function desc($a)
{
$c=array();
for($i=count($a)-1;$i>0;$i--)
{
for($j=0;$j
if($a[$j]{
$tmp=$a[$j+1];
$a[$j+1]=$a[$j];
$a[$j]=$tmp;
}
}
}
print_r($a);
}
$arr=array(33,24,56,55,59);
desc($arr);
?>
PHP冒泡排序法演示
以前面试的时候考官出的笔试题,觉得比较XX,写程序应该是在计算机上面,而不是在笔头上。
PHP程序文件sort_bubble_up.php
复制代码 代码如下:
冒泡排序法演示
//随机生成数组
$arr=array();
echo ' '; 初始值
echo '';
for($i=0;$i$arr[$i]=rand();
echo "\$arr[$i]={$arr[$i]} ";
}
//进行冒泡法排序
for($i=9;$i>0;$i--){
echo ' '; 第'.(10-$i).'次
for($j=0;$jif($arr[$j]$tmp=$arr[$j];
$arr[$j]=$arr[$j+1];
$arr[$j+1]=$tmp;
}
echo ''; ';
for($k=0;$kswitch($k){
case $j : echo ''; break;
case $j+1 : echo ''; break;
default : echo ''; ";
}
echo "\$arr[$k]={$arr[$k]}
}
echo '
}
}
//显示排序结果
echo ' '; 结果
echo ''; ';
for($i=0;$iecho "\$arr[$i]={$arr[$i]} ";
}
echo '
?>
样式表文件sort.css
复制代码 代码如下:
h1{text-align: center; color: blue;}
table{font-size: 12px; font-family: arial; background-color: black; text-align: center;}
td{background-color: white;}
.base{background-color: #0FF;}
.light{background-color: #0DD;}
.title{background-color: #3FF; text-align: center;}

JavaScript中常见的冒泡事件:掌握常用事件的冒泡特性,需要具体代码示例引言:在JavaScript中,事件冒泡是指事件会从嵌套层次最深的元素开始向外层元素传播,直到传播到最外层的父级元素。了解并掌握常见的冒泡事件,可以帮助我们更好地处理用户交互和事件处理。本文将介绍一些常见的冒泡事件,并提供具体的代码示例来帮助读者更好地理解。一、点击事件(click

JS事件中哪些不会冒泡?在JavaScript中,事件冒泡是指当一个元素触发了某个事件时,该事件会逐级向上冒泡到更高层的元素,直到冒泡到文档根节点。然后,事件处理程序会按照冒泡的顺序依次执行。然而,并不是所有的事件都会冒泡。有些事件在触发后只会执行目标元素上的事件处理程序,而不会冒泡到更高层的元素上。下面是一些常见的不会冒泡的事件:focus和blur事件:

先捕获还是先冒泡?解析事件流程的优劣势事件流程是Web开发中一个重要的概念,它描述了事件从发生到被处理的过程。在处理事件时,有两种主要的流程模型:先捕获后冒泡和先冒泡后捕获。这两种模型在不同的场景下各有优劣势,需要根据实际情况选择合适的模型。先捕获后冒泡是指在事件冒泡阶段前,先执行事件捕获阶段。事件捕获阶段从事件目标的根节点开始,逐级向下传递,直到到达目标元

学习单击事件冒泡,掌握前端开发中的关键概念,需要具体代码示例前端开发是当今互联网时代中的一个重要领域,而事件冒泡是前端开发中的一个关键概念之一。理解和掌握事件冒泡对于编写高效的前端代码至关重要。本文将介绍什么是事件冒泡,以及如何在前端开发中使用事件冒泡的概念。一、什么是事件冒泡事件冒泡是指当一个元素上的事件被触发时,会先从最内层的元素开始,然后逐级向父级元素

为何同一个事件冒泡会重复发生两次?事件冒泡是一种在浏览器中常见的事件传递机制。当一个元素触发了某个事件,这个事件将会从被触发的元素开始向上级元素依次传递,直到传递到了文档的根元素。这个过程就像水泡在水中冒起,所以被称为事件冒泡。然而,有时我们会发现同一个事件冒泡会重复发生两次,这是为什么呢?原因主要有两个方面:事件注册和事件处理。首先,我们需要明确的是,事件

单击事件冒泡的作用及其对网页交互的影响在网页开发中,事件是实现交互和响应用户操作的关键。其中,事件冒泡是一种常见的事件机制,它允许一个嵌套的元素层次结构中的事件同时被多个元素响应。本文将详细解释单击事件冒泡的作用,并说明它对网页交互的影响,同时提供一些具体的代码示例。一、单击事件冒泡的概念单击事件冒泡(ClickEventBubbling)指的是当一个元

掌握事件冒泡,轻松实现复杂交互效果,需要具体代码示例事件冒泡(EventBubbling)是前端开发中一个重要的概念,它指的是当一个元素上的事件被触发后,该事件会自动向父级元素传播,直到传播到文档根元素。掌握了事件冒泡的原理和应用,我们可以轻松实现复杂的交互效果,提升用户体验。下面将通过具体的代码示例,来帮助读者更好地理解和应用事件冒泡。代码示例一:点击展

如何利用单击事件冒泡实现更灵活的网页交互体验引言:在前端开发中,我们经常会遇到需要在网页的一部分元素上添加点击事件的情况。然而,如果页面中的元素很多,为每个元素都添加点击事件将变得非常繁琐和低效。单击事件冒泡就可以帮助我们解决这个问题,通过将点击事件添加到公共父元素上,实现更灵活的网页交互体验。一、单击事件冒泡的原理单击事件冒泡是指当一个元素上的点击事件被触


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

Dreamweaver Mac版
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

記事本++7.3.1
好用且免費的程式碼編輯器