冒泡排序(Bubble Sort)是一种简单的排序算法。它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。
list = [1, 2, 5, 3, 1, 8, 4]
def bubble_sort(list):
length = len(list)
# 第一级遍历
for index in range(length): #一次循环结果[1, 2, 3, 5, 8, 4, 9]需要多次循环再将4左移两个位置
print index,'长度:',length
# exit()
# 第二级遍历
# flag = True
for j in range(1, length - index):#计数从range的1开始,让最后一个数字为list[j],length - index每次循环完成(最右边的数已经最大,也就是排好序了)就减少范围
print list[j - 1],list[j],j
if list[j - 1] > list[j]:
# 交换两者数据,这里没用temp是因为python 特性元组。
list[j - 1], list[j] = list[j], list[j - 1]
# flag = False
print list
# if flag:
# # 没有发生交换,直接返回list
# return list
return list
print '排序完成:',bubble_sort(list)
php冒泡
$arr = array(3,6,2);
for($i = count($arr)-1;$i>=0;$i--){//缩小范围
for($j = 0 ; $j < $i ; $j++){
if($arr[$j+1] > $arr[$j] ){//相邻两个数比较,如果后一个数大于前一个就互相交换位置,所以每次循环结束排在最右边的永远是最小的(冒泡)。
$asdf = $arr[$j];
$arr[$j] = $arr[$j + 1];
$arr[$j + 1] = $asdf;
}
}
}
print_r($arr);