冒泡排序Bubble Sort的PHP实现。代码中函数说明:
- out_arr,用于将数组输出成一个字符串,以便查看
- bubblesort,第一种实现方案,从后往前依次选出需要的值,这里是较大的
- bubblesort2,第二种方案,从前往后一次选中需要的值,这里是最小的
- range,产生一个1到20的数组
- shuffle,打乱数组
01
function out_arr($arr) {
02
return implode(', ', $arr).'
03
';
04
}
05
06
function bubblesort($arr) {
07
for ($i = 0; $i < count($arr) - 1; $i++ ) {
08
for($j = 0; $j < count($arr) - $i - 1; $j++ ) {
09
if( $arr[$j] > $arr[$j+1] ) {
10
$tmp = $arr[$j];
11
$arr[$j] = $arr[$j + 1];
12
$arr[$j + 1] = $tmp;
13
}
14
}
15
echo sprintf('%3d', $i).' : '.out_arr($arr);
16
}
17
}
18
19
20
function bubblesort2($array) {
21
$count = count($array);
22
for($i=0; $i<$count; $i++) {
23
for($j=$count-1; $j>$i; $j--) {
24
if ($array[$j] < $array[$j-1]) {
25
$tmp = $array[$j];
26
$array[$j] = $array[$j-1];
27
$array[$j-1] = $tmp;
28
}
29
}
30
echo sprintf('%3d', $i).' : '.out_arr($array);
31
}
32
return $array;
33
}
34
echo '<pre>';
35
$arr = range(1, 20);
36
shuffle($arr);
37
echo 'ORG : '.out_arr($arr);
38
bubblesort2($arr);
39
echo '</pre>';
冒泡排序Bubble Sort的PHP实现。代码中函数说明:
- out_arr,用于将数组输出成一个字符串,以便查看
- bubblesort,第一种实现方案,从后往前依次选出需要的值,这里是较大的
- bubblesort2,第二种方案,从前往后一次选中需要的值,这里是最小的
- range,产生一个1到20的数组
- shuffle,打乱数组
01 |
function out_arr($arr) { |
02 |
return implode(', ', $arr).' |
06 |
function bubblesort($arr) { |
07 |
for ($i = 0; $i < count($arr) - 1; $i++ ) { |
08 |
for($j = 0; $j < count($arr) - $i - 1; $j++ ) { |
09 |
if( $arr[$j] > $arr[$j+1] ) { |
11 |
$arr[$j] = $arr[$j + 1]; |
15 |
echo sprintf('%3d', $i).' : '.out_arr($arr); |
20 |
function bubblesort2($array) { |
21 |
$count = count($array); |
22 |
for($i=0; $i<$count; $i++) { |
23 |
for($j=$count-1; $j>$i; $j--) { |
24 |
if ($array[$j] < $array[$j-1]) { |
26 |
$array[$j] = $array[$j-1]; |
30 |
echo sprintf('%3d', $i).' : '.out_arr($array); |
37 |
echo 'ORG : '.out_arr($arr); |
- 冒泡排序和选择排序(bubble sort and selection sort)
Bubble sort Basic Method: import random nums = [random.randint(1,20) for _ in range(10)] #制作一个无序数字列表 ...
- Bubble Sort(冒泡排序)
冒泡排序(英语:Bubble Sort,台湾另外一种译名为:泡沫排序)是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行 ...
- Java中的经典算法之冒泡排序(Bubble Sort)
Java中的经典算法之冒泡排序(Bubble Sort) 神话丿小王子的博客主页 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一 ...
- HDU 5775 Bubble Sort(冒泡排序)
p.MsoNormal { margin: 0pt; margin-bottom: .0001pt; text-align: justify; font-family: Calibri; font-s ...
- 冒泡排序(Bubble Sort)
常见的排序算法有Bubble Sort.Merge Sort.Quick Sort 等,所有排序算的基本法思想都是把一个无限大的数据规模通过算法一步步缩小,指导最后完成排序. 这里分享一下Buuble ...
- [算法] 冒泡排序 Bubble Sort
冒泡排序(Bubble Sort,台湾另外一种译名为:泡沫排序)是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没 ...
- c++算法联系,冒泡排序,bubble sort,插入排序,insert sort,
#include <iostream.h> #define MAX 100 void dispaly(int a[],int n) { for(int i=0;i<n;i+ ...
- java排序算法之冒泡排序(Bubble Sort)
java排序算法之冒泡排序(Bubble Sort) 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2个数 ...
- 排序算法 (sorting algorithm)之 冒泡排序(bubble sort)
http://www.algolist.net/Algorithms/ https://docs.oracle.com/javase/tutorial/collections/algorithms/ ...
随机推荐
- Oracle学习笔记—Oracle左连接、右连接、全外连接以及(+)号用法(转载)
转载自: Oracle左连接.右连接.全外连接以及(+)号用法 对于外连接,Oracle中可以使用“(+)”来表示. 关于使用(+)的一些注意事项: (+)操作符只能出现在WHERE子句中,并且不能与 ...
- Verilog HDL设计规范及经验谈(转载)
1. 规范很重要 工作过的朋友肯定知道,公司里是很强调规范的,特别是对于大的设计(无论软件还是硬件),不按照规范走几乎是不可实现的.逻辑设计也是这样:如果不按规范做的话,过一个月后调试时发现 ...
- 视频解码芯片SAA7111A的初始化
为了完成SAA7111A的初始化,FPGA需要完成I2C控制器的设计. 之前本科的时候初步接触过I2C,但是编写一个Verilog的控制器还是觉得有点难度的.说实话,那时候都无从下手,对实现这样一个协 ...
- 剑指offer 面试61题
面试61题: 题目:LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到 ...
- 【转】web.xml中load-on-startup的作用
http://www.blogjava.net/xzclog/archive/2011/09/29/359789.html 如下一段配置,熟悉DWR的再熟悉不过了:<servlet> ...
- Informatica can bind a LONG value only for insert into a LONG column Oracle
Informatica实现etl同步表数据信息时 报: Severity Timestamp Node Thread Message Code Message ERROR 2016/8/8 17:32 ...
- PHP用星号隐藏部份用户名、身份证、IP、手机号、邮箱等实例
一.仿淘宝评论购买记录隐藏部分用户名,以下代码亲测可用. function cut_str($string, $sublen, $start = 0, $code = 'UTF-8') { if( ...
- HackerRank - maximum-perimeter-triangle 【水】
题意 给出一系列数字,判断其中哪三个数字可以构成一个三角形,如果有多个,输出周长最大的那个,如果没有输出 - 1 思路 数据较小,所有情况FOR一遍 判断一下 AC代码 #include <cs ...
- Linux进程优先级查看及修改
进程cpu资源分配就是指进程的优先权(priority).优先权高的进程有优先执行权利.配置进程优先权对多任务环境的Linux很有用,可以改善系统性能.还可以把进程运行到指定的CPU上,这样一来,把不 ...
- css系列(5)css的运用(一)
从本节开始介绍css配合html可以达到的一些效果. (1)导航栏: <html> <head> <title>示例5.1</title> ...