python实现八大排序算法(2)

yizhihongxing

Python实现八大排序算法(2)

在本文中,我们将继续讲解Python实现八大排序算法的内容,包括选择排序、插入排序、希尔排序、并排序、快速排序、堆、计数排序桶排序。

选择排序

选择排序是一种简单的排序算法,它的基本思想是每次从未排序的元素中选择最小的元素,放到已排序的尾。选择排序的时间复杂度为(n^2)。

下面Python实现选择排序的代码:

def selection_sort(arr):
    n = len(arr)
    for i in range(n):
        min_index = i
        for j in range(i+1, n):
            if arr[j] < arr[min_index]:
                min_index = j
        arr[i], arr[min_index] = arr[min_index], arr[i]
    return arr

下面是一个示例,演示如何使用选择排序对一个列表进行排序:

arr = [64, 25, 12, 22, 11]
sorted_arr = selection_sort(arr)
print(sorted_arr)    # 输出:[11, 12, 22, 25, 64]

在这个示例中,我们首先定义了一个列表arr,然后使用选择排序对它进行排序,并将排序后的结果打印出来。

插入排序

插入排序是一种简单的排序算法,它的基本思想是将未排序的元素插入到已排序的部分中。插入排序的时间复杂度为O(n^2)。

下面是Python实现插入排序的代码:

def insertion_sort(arr):
    n = len(arr)
    for i in range(1, n):
        key = arr[i]
        j = i - 1
        while j >= 0 and key < arr[j]:
            arr[j+1] = arr[j]
            j -= 1
        arr[j+1] = key
    return arr

下面是一个示例,演示如何使用插入排序对一个列表进行排序:

arr = [64, 25 12, 22, 11]
sorted_arr = insertion_sort(arr)
print(sorted_arr)    # 输出:[11, 12, 22, 25, 64]

在这个示例中,我们首先定义了一个列表arr,然后使用插入排序对它进行排序,并将排序后的结果印出来。

希尔排序

希尔排序是一种改进的插入排序算法,它的基本思想是将列表分成若干子序列,对每个子序进行插入排序,然后逐步缩小子序列的长度,最终完成排序。希尔排序的时间复杂度为O(nlogn)。

面是Python实现希尔排序的代码:

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

下面是一个示例,演示如何使用希尔排序对一个列表进行排序:

arr = [64, 25, 12, 22, 11]
sorted_arr = shell_sort(arr)
print(sorted_arr)    # 输出:[11, 12, 22, 25, 64]

在这个示例中,我们首先定义了一个列表arr,然后使用希尔排序对它进行排序,并将排序后的结果打印出来。

归并排序

归并排序是一种分治算法,它的基本思想是将列表分成若干个子序列,每个子序列进行排序,然后将排好序的子序列合并成一个大的有序序列。归排序的时间复杂度O(nlogn)。

下面是Python实现归并排序的代码:

def merge_sort(arr):
    if len(arr) > 1:
        mid = len(arr) // 2
        left_arr = arr[:mid]
        right_arr = arr[mid:]
        merge_sort(left_arr)
        merge_sort(right_arr)
        i = j = k = 0
        while i < len(left_arr) and j < len(right_arr):
            if left_arr[i] < right_arr[j]:
                arr[k] left_arr[i]
                i += 1
            else:
                arr[k] = right_arr[j]
                j += 1
            k += 1
        while i < len(left_arr):
            arr[k] = left_arr[i]
            i += 1
            k += 1
        while j < len(right_arr):
            arr[k] = right_arr[j]
            j += 1
            k += 1
    return arr

下面是一个示例,演示如何使用归并排序对一个列表进行排序:

arr = [64, 25, 12, 22, 11]
sorted_arr = merge_sort(arr)
print(sorted_arr)    # 输出:[11, 12, 22, 25, 64]

在这个示例中,我们首先定义了一个列表arr,然后使用归对它进行排序,并将排序后的结果打印出来。

快速排序

快速排序一种分治算法,它的基本思想选择一个基准元素,将列表分成两个子序列,小于基准元素的放在左边,大于基准元素的放在右边,然后递归地对左右两个子列进行排序。快速排序的时间复杂度为O(nn)。

下面是Python现快速排序的代码:

def quick_sort(arr):
    if len(arr) <= 1:
        return arr
    pivot = arr[len(arr) // 2]
    left_arr = [x for x in arr if x < pivot]
    middle_arr = [x for x in arr if x == pivot]
    right_arr = [x for x in arr if x > pivot]
    return quick_sort(left_arr) + middle_arr + quick_sort(right_arr)

下面是一个示例,演示如何使用快速排序对一个列表进行排序:

arr = [64, 25, 12, 22, 11]
sorted_arr = quick_sort(arr)
print(sorted_arr)    # 输出:[11, 12, 22, 25, 64]

这个示例中我们首先定义了一个列表,然后使用快速排序对它进行排序,并将排序后的结果打印出来。

另一个示例,演示如何使用两个列表里元素对应相乘的方法计算两个向量的点积:

vector1 = [1, 2, 3]
vector2 = [4, 5, 6]
dot_product = sum([a * b for a, b in zip(vector1, vector2)])
print(dot_product)    # 输出:32

在这个示例中,我们首先定义了两个向量vector1和vector2,然后使用两个列表里素对应相乘的方法计算它们的点积,并将结果打印出来。

总之,使用zip函数和列表推导式可以很方便地实现两个列表里元素对应相乘的方法,适用于各种需要对应元素相乘的场景。

堆排序

堆排序是一种树形选择排序算法,它的基本思想是将列表看成一个完全二叉树,将其转换成一个大根堆或小根堆,然后将堆顶元素与底素交换,再将剩余元素重新调整成一个堆,重复以上步骤,直到整个序列有序。堆排序的复杂为(nlogn)。

下面是Python实现堆排序的代码:

def heap_sort(arr):
    def heapify(arr, n, i):
        largest = i
        l = 2 * i + 1
        r = 2 * i + 2
 if l < n and arr[i] < arr[l]:
            largest = l
        if r < n and arr[largest] < arr[r]:
            largest = r
        if largest != i:
            arr[i], arr[largest] = arr[largest], arr[i]
            heapify(arr, n, largest)
    n = len(arr)
    for i in range(n//2-1, -1, -1):
        heapify, n, i)
    for i in range(n-1, 0, -1):
        arr[i], arr[0] = arr[0], arr[i]
        heapify(arr, i, 0)
    return arr

下面是一个示例,演示如何使用排序对一个列表进行排序:

arr = [64, 25, 12, 22, 11]
sorted_arr = heap_sort(arr)
print(sorted_arr)    # 输出:[11, 12, 22, 25, 64]

在这个示例中我们首先定义了一个列表arr,然后使用堆排序对它进行排序,并将排序后的结果打印出来。

数排序

计数排序是一种非比较排序算法,它的基本思想是统计每个元素出现的次数,然根据元素出现的次数将元素排序。计数排序的时间复杂度为O(n+k),其中k是元素的范围。

下面是Python实现计数的代码:

def counting_sort(arr):
    n = len(arr)
    output = [0] * n
    count = [0] * (max(arr)+1)
    for i in range(n):
        count[arr[i]] += 1
    for i in range(1, len(count)):
        count[i] += count[i-1]
    for i in range(n-1, -1, -1):
        output[count[arr[i]]-1] = arr[i]
        count[arr[i]] -= 1
    for i in range(n):
        arr[i] = output[i]
    return arr

下面是一个示例,演示如何使用计数排序对一个列表进行排序:

arr = [64, 25, 12, 22, 11]
sorted_arr = counting_sort(arrprint(sorted_arr)    # 输出:[11, 12, 22, 25, 64]

在这个示例中,我们首先定义了一个列表arr,然后使用计数排序对它进行排序将排序后的结果打印出来。

桶排序

桶排序是一种非比较排序算法,它的基本思想是将元素分到不同的桶中,对每个桶中的元素进行排序,然后将所有桶中的元素按顺序合并起来。桶排序的时间复杂度为O(n+k),其中k是桶的数量。

下面是Python实现桶排序的代码:

def bucket_sort(arr):
    n = len(arr)
    max_val = max(arr)
    bucket_size = max_val // n + 1
    buckets = [[] for _ in range(bucket_size)]
    for i in range(n):
        bucket_index = arr[i] // bucket_size
        buckets[bucket_index].append(arr[i])
    for i in range(bucket_size):
        buckets[i].sort()
    output = []
    for i in range(bucket_size):
        output += buckets[i]
    return output

下面是一个示例,演示如何使用桶排序对一个列表进行排序:

arr = [64, 25, 12, 22, 11]
sorted_arr = bucket_sort(arrprint(sorted_arr)    #:[11, 12, 22, 25, 64]

在这个示例中,我们首先定义了一个列表arr,然后使用桶排序对它进行排序,并将排序后的结果印出来。

总结

在本文中,我们讲解了Python实现八大排序算法的内容,包括选择排序、插入排序、希尔排序、归并排序、快速排序、堆排序、计数排序和桶排序。这些排序算法各有优缺点,应根据具体情况选择合适的算法。

总之,这些排序算法是Python编程中非常重要的基础知识,掌握它们可以帮助我们更好地理解和应用Python编程语言。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:python实现八大排序算法(2) - Python技术站

(0)
上一篇 2023年5月13日
下一篇 2023年5月13日

相关文章

  • pytorch 获取层权重,对特定层注入hook, 提取中间层输出的方法

    获取层权重 要获取 PyTorch 神经网络模型的某一层的权重,需要先加载模型,然后通过访问模型参数来获取每一层的权重。以下是一个获取模型特定层权重的示例: import torch from torchvision import models # 加载预训练的 ResNet18 模型 model = models.resnet18(pretrained=T…

    python 2023年6月3日
    00
  • Python实现以时间换空间的缓存替换算法

    Python 实现以时间换空间的缓存替换算法 什么是缓存替换算法? 缓存替换算法是计算机领域中常见的一种算法,用于在计算机内存中管理缓存数据。在计算机内部,内存访问(即从内存中读取数据)通常比从磁盘中读取数据更快,因此在需要频繁读取的数据中,将其存储在内存中的缓存中,可以提高应用程序的性能。 然而,由于内存的限制,缓存中存储的数据量有限,如果新增加的数据无法…

    python 2023年6月2日
    00
  • python解析库Beautiful Soup安装的详细步骤

    BeautifulSoup是一个Python解析库,用于从HTML和XML文档中提取数据。本攻略将提供安装BeautifulSoup的详细步骤,并提供两个示例,演示如何使用BeautifulSoup解析HTML文档。 安装BeautifulSoup 以下是安装BeautifulSoup的详细步骤: 确认已安装pip 在安装BeautifulSoup之前,需要…

    python 2023年5月15日
    00
  • python把数组中的数字每行打印3个并保存在文档中的方法

    要将Python中的数组中的数字每行打印3个并保存在文档中,可以按照以下步骤进行: 第一步:创建一个数组 在 Python 中,可以用以下语句创建一个包含数字的数组: my_array = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15] 第二步:迭代数组并打印每行3个数字 代码如下: count = 0…

    python 2023年6月6日
    00
  • opencv+tesseract实现验证码识别的示例

    下面就来详细讲解“opencv+tesseract实现验证码识别的示例”的完整攻略。 一、准备工作 首先,在开始实现之前,我们需要先完成一些准备工作,包括: 安装OpenCV和Tesseract:这两个库是实现本文中验证码识别的核心,需要先安装; 获取验证码:我们需要从某个网站上爬取用于识别的验证码图片,这里可以自行寻找需要的网站进行爬取; 确定识别方式:针…

    python 2023年5月18日
    00
  • python实现kNN算法识别手写体数字的示例代码

    现在我来为你讲解Python实现kNN算法识别手写体数字的示例代码的完整攻略。本文主要包含以下几个部分: kNN算法简介 数据集介绍 实现过程 示例说明 总结 1. kNN算法简介 kNN算法是一种基于距离度量进行分类的机器学习算法。其全称为k-Nearest Neighbor(k近邻)算法。kNN算法的核心思想是:如果一个样本在特征空间中的k个最相似(即特…

    python 2023年6月6日
    00
  • Python统计列表元素出现次数的方法示例

    下面是关于Python统计列表元素出现次数的方法的攻略。 什么是列表元素出现次数? 在Python中,列表是由多个元素组成的数据结构。在处理列表时,有时需要统计每个元素出现的次数。例如,对于一个数字列表,我们可能需要查找其中出现最多的数字,或者找到所有出现次数超过一个特定阈值的数字。 方法一:使用count()函数 Python中的列表对象有一个count(…

    python 2023年6月3日
    00
  • 开发 python wsgi 应用程序时 Apache 重启

    【问题标题】:Apache restart when developing python wsgi apps开发 python wsgi 应用程序时 Apache 重启 【发布时间】:2023-04-03 10:28:01 【问题描述】: 我正在评估用于 Web 开发的 python (mod_wsgi),并注意到在 Windows 上我必须在更改我的 py…

    Python开发 2023年4月8日
    00
合作推广
合作推广
分享本页
返回顶部