Python_冒泡排序

2018-09-18 06:43:13来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

从小到大的排序:(最前面的数和一步步和后面的数比较,如果大于则交换,如果不大于则继续循环)

方法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]

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:干掉Java后,Python薪酬榜第一了!(文末送书)

下一篇:python scrapy爬取知乎问题和收藏夹下所有答案的内容和图片