python:实现冒泡排序

冒泡排序的原理为数组之间,两两比较,以此把最大的往后放,逐步替换就能够完成排序!比如下面给出一组数:
排序前:[24,69,80,57,13]
第1次比较后:[24,69,57,13,80]
第2次比较后:[24,57,13,69,80]
第3次比较后:[24,13,57,69,80]
第4次比较后:[13,24,57,69,80]

通过第一次排序,将最大的80往后放,以次放入69,57,24,13。
代码如下:

s=list(map(int, input().split(" "))) #输入需要排序的数,以1 8 3 2 5进行输入
#print(sorted(s))
for i in range(len(s)-1):            #这里的i是求解整个列表的长度,并且要-1
    for j in range(len(s)-i-1):      #在排序的过程中以此两两比较,把最大的放在最后
        if s[j]>s[j+1]:              #判断前一个是否大于后一个
            temp=s[j]                #将大于后一个的前一个值存储在temp中,用于替换s[j+1]上的值
            s[j]=s[j+1]              #将小的往前面移动,因此把s[j]替换为s[j+1]
            s[j+1]=temp              #将大的值往后移动,以此s[j+1]替换为前面比他大的数s[j]
print(s)

输出结果为:

1 8 3 2 5
[1, 2, 3, 5, 8]

Process finished with exit code 0
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秋刀鱼程序编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值