经典面试题---进阶版冒泡排序

常规版

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#!/usr/bin/env python3
# -*- coding: utf-8 -*-


def foo(data):
"""常规版"""
for i in range(len(data)):
for j in range(len(data)-i-1):
if data[j] > data[j+1]:
data[j], data[j + 1] = data[j + 1], data[j]
return data


if __name__ == '__main__':
data = [3, 0, 5, 4, 2, 6, 8, 1, 9, 7]
print(data)
print(foo(data))

进阶版

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#!/usr/bin/env python3
# -*- coding: utf-8 -*-


def bubble_sort(data):
"""
进阶版
最坏情况 时间复杂度 O(n**2)
最好情况 时间复杂度 O(n)
稳定排序法
空间复杂度最佳 只需要一个额外空间
适用于数据量小或有部分数据已经排过序的情况
:param data:
:return:
"""
# i 倒序循环列表排序
for i in range(len(data)-1, -1, -1):
flag = False # flag判断是否执行了交换操作
for j in range(i): # i 为倒序循环,所以j的最大值即是i 0~i
if data[j] > data[j + 1]:
data[j], data[j + 1] = data[j + 1], data[j]
flag = True # 执行过交换操作,把flag置为True
if not flag: # 执行完一次扫描后,判断是否执行过交换操作,如果没有交换过数据,就表示此时数组已完成排序,故直接跳出循环
break
print('第{0}次排序: {1}'.format(len(data)-i, data))
return data


if __name__ == '__main__':
data = [3, 0, 5, 4, 2, 6, 8, 1, 9, 7]
print(data)
print(bubble_sort(data))

评论