简单排序算法之冒泡

import random
import pretty_errors

#isSorted用来检测数据是否已经有序,在内层循环时如果没有进行交换变量则表示数据已经排序完成,就不用再继续循环了
#sortBoard用来检测每次内部循环的边界,边界后面的数已经有序,不用再比较
def bubbleSort(data):
	length = len(data)
	sortBoard = length-1
	for i in range(length):
		isSorted = True
		for j in range(sortBoard):
			if(data[j] > data[j+1]):
				#交换变量
				data[j], data[j+1] = data[j+1], data[j]
				isSorted = False
				lastchange = j

		sortBoard = lastchange
		if isSorted:
			break
#打印输出
def printf(data_p, state):
	for i in state:
		print(i, end = '')
	print(":")

	for i in data_p:
		print(i, end = ' ')
	print('\n')

def main():
	data = []
	for i in range(30):
		data.append(random.randint(-1000, 1000))

	printf(data, "raw data")
	bubbleSort(data)
	printf(data, "sorted data")

if __name__ == '__main__':
	main()

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值