IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Python数据结构-排序算法 -> 正文阅读

[数据结构与算法]Python数据结构-排序算法

冒泡排序:

def bubble_sort(alist):
    for i in range(len(alist)-1,0,-1):
        for j in range(i):
            if alist[j]>alist[j+1]:
                alist[j],alist[j+1] = alist[j+1],alist[j]

li = [54,26,93,17,77,31,44,55,20]
bubble_sort(li)
print(li)

结果:

[93, 77, 55, 54, 44, 31, 26, 20, 17]

选择排序:

def select_sort(alist):
    n=len(alist)
    for i in range(n-1):
        min_index = i
        for j in range(i+1,n):
            if alist[j] < alist[min_index]:
                min_index = j
        if min_index != i:
            alist[i],alist[min_index] = alist[min_index],alist[i]

li = [54,26,93,17,77,31,44,55,20]
select_sort(li)
print(li)

结果:

[17, 20, 26, 31, 44, 54, 55, 77, 93]

插入排序:

def insert_sort(alist):
    for i in range(1,len(alist)):
        for j in range(i,0,-1):
            if alist[j]<alist[j-1]:
                alist[j],alist[j-1] = alist[j-1],alist[j]

li = [54,26,93,17,77,31,44,55,20]
insert_sort(li)
print(li)

结果:

[17, 20, 26, 31, 44, 54, 55, 77, 93]

希尔排序:

def shell_sort(arry):
    n = len(arry)
    gap = n//2
    while gap>0:
        for i in range(gap,n):
            j = i
            while(j>=gap and arry[j-gap] > arry[j]):
                arry[j-gap],arry[j] = arry[j],arry[j-gap]
                j -= gap

        gap = gap//2

alist = [54,26,93,17,77,31,44,55,20,12]
shell_sort(alist)
print(alist)

[12, 17, 20, 26, 31, 44, 54, 55, 77, 93]

快速排序:

def quick_sort2(arry,start,end):
    if start>=end:
        return

    piv = arry[start]
    left = start
    right = end

    while left<right:
        while left<right and arry[right]>=piv:
            right -=1
        arry[left] = arry[right]

        while left<right and arry[left]<piv:
            left += 1
        arry[right] = arry[left]

    arry[right] = piv

    quick_sort2(arry,start,right-1)

    quick_sort2(arry,right+1,end)

li=[54,26,93,17,77,31,44,55,20]
quick_sort2(li,0,len(li)-1)
print(li)

[17, 20, 26, 31, 44, 54, 55, 77, 93]

归并排序:

def merge_sort(arry):
    if len(arry)<=1:
        return arry

    mid = len(arry)//2

    # 左侧递归调用归并排序到有序
    left_arry = merge_sort(arry[:mid])
    # 右侧递归调用归并排序到有序
    right_arry = merge_sort(arry[mid:])

    l , r = 0,0
    result =[]
    while l<len(left_arry) and r<len(right_arry):
        if left_arry[l]<right_arry[r]:
            result.append(left_arry[l])
            l+=1
        else:
            result.append(right_arry[r])
            r += 1

    result = result + left_arry[l:]
    result = result + right_arry[r:]

    return result

alist = [54,26,93,17,77,31,44,55,20,12]
new = merge_sort(alist)
print(new)

[12, 17, 20, 26, 31, 44, 54, 55, 77, 93]

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-08-25 12:27:44  更:2021-08-25 12:28:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 22:40:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码