从小到大的排序:(最前面的数和一步步和后面的数比较,如果大于则交换,如果不大于则继续循环)
方法1:
data = [65, 1, 45, 77, 3, 9, 43, 23, 7, 53, 213, 10]
for i in range(1, len(data)):
# 因为j+1在列表最后加到了大于列表数的值,所以只要刚好循环到列表结束就可以了
for j in range(len(data)-i): # 减去列表循环的次数
if data[j] > data[j+1]:
tmp = data[j+1]
data[j+1] = data[j]
data[j] = tmp
print(data)
方法2(和方法1相比,略过了最后两次比较的循环):
for i in range(len(data)-2): # 把最后两次循环略过,最后两次不用比较
for j in range(len(data)-i-1): # 让j 不超出长度
if data[j] > data[j + 1]:
tmp = data[j+1]
data[j+1] = data[j]
data[j] = tmp
print(data)
结果:
[1, 3, 7, 9, 10, 23, 43, 45, 53, 65, 77, 213]