Python算法之冒泡排序001

这是我学习python后学习的第一个排序算法。

排序需要关注两个维度,一是时间复杂度,二是稳定性。

冒泡排序的时间复杂度为O(n^2);属于稳定排序算法。

冒泡排序原理:有一个无序数组(A,下标为i,元素个数为n),要对无需数组进行排序。第一轮比较:第一步开始进行相邻两个元素的对比,若第1个位于第2位,交换他们的位置;第二步,用刚才比较大的那个数字和第3位数比较,谁大谁就在第3位。。。以此类推,直至最大的数放在最后一位。第二轮比较:重复第一轮的方法,直至第n-1轮(即len(A[i])-1)轮比较,此时我们便得到了一个有序的数组。

优化方案:从上边的原理可以看出,冒泡排序每轮比较都需要进行n-1次两两比较;但是我们可以知道,每做完一轮比较,最后一个位置的数就已经定下来了,所以,我们可以在后续每轮的比较中,减少一次两两比较。

好啦,准备工作已说完,python源码现身:

# coding:utf-8

# 冒泡排序

defpaopao(A):

    print A

for i in range(len(A)-1,0,-1):    # 外层循环是要比较的次数

    print i

    for j in range(i):    # 内层循环是两两比较,交换

        if A[j] > A[j+1]:

            A[j],A[j+1] = A[j+1],A[j]# python特有的交换两个元素的公式

            # max1 = A[j]

            # A[j] = A[j+1]

            # A[j+1] = max1

        print A

if__name__ =="__main__":

    s = [8,6,7,4,2,3,5]

    # 打印原数组

    print s

    # 打印排序后的数组

    paopao(s)

    print s


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 总结一下常见的排序算法。 排序分内排序和外排序。内排序:指在排序期间数据对象全部存放在内存的排序。外排序:指在排序...
    jiangliang阅读 1,485评论 0 1
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 3,805评论 0 15
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,287评论 0 52
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 1,327评论 0 2
  • dsfsaf
    hozdanny阅读 104评论 0 1

友情链接更多精彩内容