Python数据结构与算法(几种排序)小结

下面是关于“Python数据结构与算法(几种排序)小结”的完整攻略。

1. 排序算法简介

排序算法是一种将一组数据按照一定规则排列的算法。在计算机科学中,常见的算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序等。

2. Python实现常见排序算法

2.1 冒泡排序

冒泡排序是一种通过交换相邻元素来排序的算法。Python中,我们可以使用以下代码实现冒泡排序:

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

在这个代码中,我们定义了 bubble_sort() 函数来实现冒泡排序。我们使用两个嵌套的循环来遍历数组,并通过比较邻元素来交换它们的位置。最后返回排序后的数组。

下面是一个使用冒泡排序的示例:

arr = [64, 34, 25, 12, 22, 11, 90]
print(bubble_sort(arr))

在这个示例,我们使用 bubble_sort() 函数对数组进行排序,并打印排序后的结果。

2.2 选择排序

选择排序是一种通过选择最小元素来排序的算法。在Python中,我们可以使用以下代码实现选择排序:

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

在这个代码中,我们定义了 selection_sort() 函数来实现选择排序。我们使用两个嵌套的循环来遍历数组,并通过比较元素来选择最小元素的位置。最后,我们返回排序后的数组。

下面是一个使用选择排序的示例:

arr = [64, 34, 25, 12, 22, 11, 90]
print(selection_sort(arr))

在这个示例中,我们使用 selection_sort() 函数对数组进行排序,并打印排序后的结果。

2.3 插入排序

插入排序是一种通过插入元素排序的算法。在Python中,我们可以使用以下代码实现插入排序:

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

在这个代码中,我们定义了 insertion_sort() 函数来实现插入排序。我们使用一个循环来遍历数组,并将每个元素插入到已排序的子数组中。最后,我们返回排序后的数组。

下面是一个插入排序的示例:

arr = [64, 34, 25, 12, 22, 11, 90]
print(insertion_sort(arr))

在这个示例中,我们使用 insertion_sort() 函数对数组进行排序,并打印排序后的结果。

2.4 快速排序

快速排序是一种通过分治法来排序的算法。Python中,我们可以使用以下代码实现快速排序:

def quick_sort(arr):
    if len(arr) <= 1:
        return arr
    pivot = arr[len(arr)//2]
    left = [x for x in arr if x < pivot]
    middle = [x for x in arr if x == pivot]
    right = [x for x in arr if x > pivot]
    return quick_sort(left) + middle + quick_sort(right)

在这个代码中,我们定义了 quick_sort() 函数来实现快速排序。我们先选择一个基准元素,然后将数组分成三个部分:小于基准元素的部分、等于基准元素的部分和大于基准元素的部分。最后,我们递归地对小大于基准素的部分进行,并将它们与等于基准元素的部分合并起来。

下面是一个使用快速排序的示例:

arr = [64, 34 25, 12, 22, 11, 90]
print(quick_sort(arr))

在这个示例中,我们使用 quick_sort() 函数对数组进行排序,并打印排序后的结果。

2.5 归并排序

并排序是一通过分治法来排序的算法。在Python中,我们可以使用以下代码实现归并排序:

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

在这个代码中,我们定义了 merge_sort() 函数来实现归并排序。我们首先将数组分成两个部分,然后递归地对它们进行排序最后,我们将它们合并起来。

下面是一个使用归并排序的示例:

arr = [64, 34, 25, 12, 22, 11, 90]
print(merge_sort(arr))

在这个示例中,我们使用 merge_sort() 函数对数组进行排序,并打印排序后的结果。

3. 总结

排序算法是一种一组数据按照一定规则进行排列的算法。在Python中,常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序等。在实现这些算法时,我们需要使用相应的代码来遍历数组、比较元素、交换位置等。最后,我们可以返回排序后的数组。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Python数据结构与算法(几种排序)小结 - Python技术站

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

相关文章

  • python pandas写入excel文件的方法示例

    下面是 “python pandas写入excel文件的方法示例” 的完整实例教程及两个示例说明。 1. 简介 Pandas 是一种优秀的 Python 数据分析库,不仅可以在数据的处理上做到快速和高效,还可以轻松地进行数据清洗、处理和可视化等操作。Pandas 提供了多种对 Excel 文件操作的方法,我们可以将数据写入到 Excel 文件,以供后续操作。…

    python 2023年5月13日
    00
  • 获取python运行输出的数据并解析存为dataFrame实例

    要获取Python运行输出的数据并解析存为dataFrame实例,需要使用Python的标准库subprocess和pandas。 步骤如下: 编写可以输出数据的Python脚本或命令行命令。比如下面这个Python脚本,它会计算斐波那契数列,并将结果打印到控制台: “`pythondef fibonacci(n): if n <= 2: retur…

    python 2023年6月5日
    00
  • Python爬虫:url中带字典列表参数的编码转换方法

    当Python爬虫需要将字典或列表参数作为查询参数添加到URL链接中时,需要对其进行编码转换,否则在程序访问该链接时可能出现问题。以下是完整的攻略: 1. 理解URL的编码格式 URL编码格式指将URL链接中的特殊字符使用特定的编码方式进行转换,使得这些字符能够被顺利传递且不造成歧义。常见的URL编码方式为UTF-8编码方式。 例如,对于一个URL链接 ht…

    python 2023年5月31日
    00
  • 用Python将结果保存为xlsx的方法

    接下来我将为您提供用Python将结果保存为xlsx文件的完整攻略。 1. 安装依赖库 在使用Python保存为xlsx文件之前,我们需要先安装openpyxl库,它是一个用于操作Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库,安装方法如下: pip install openpyxl 2. 导入openpyxl库 安装成功后…

    python 2023年6月3日
    00
  • Python中八种数据导入方法总结

    下面我来详细讲解一下“Python中八种数据导入方法总结”的完整实例教程。 介绍 数据导入是数据分析的第一步,Python中有多种数据导入方法,本文将总结Python中的八种常用数据导入方法,并通过示例演示其使用。 方法一:使用read_csv()函数读取CSV文件 CSV文件是一种常见的数据格式,使用pandas库的read_csv()函数可以快速读取CS…

    python 2023年5月13日
    00
  • 详解Python3.6的py文件打包生成exe

    下面我就详细讲解“详解Python3.6的py文件打包生成exe”的完整攻略。 简介 在Python开发中,经常需要将程序包装成exe文件形式,从而实现批量处理、部署、传输等功能。Python3中,我们可以使用pyinstaller模块来实现将.py文件打包成.exe文件。 打包过程 安装pyinstaller模块 首先,我们需要安装pyinstaller模…

    python 2023年5月14日
    00
  • 利用python 下载bilibili视频

    以下是利用Python下载B站视频的完整攻略: 获取B站视频的真实地址 B站视频地址是加密的,我们需要通过某些方法获取其真实地址。这里介绍两种获取方法: 方法一:使用B站API 我们可以使用B站提供的API来获取视频信息,通过解析视频信息中的真实地址即可下载视频。下面演示如何使用API获取信息并解析出真实地址: import requests import …

    python 2023年6月3日
    00
  • Python3 json模块之编码解码方法讲解

    Python3 json模块之编码解码方法讲解 什么是JSON JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它是基于JavaScript的一个子集。JSON采用完全独立于语言的文本格式,这使得它非常适合于数据的传输。同时,JSON的格式也非常易于人阅读和编写,也容易被机器解析和生成。在Web应用中,JSON由…

    python 2023年5月31日
    00
合作推广
合作推广
分享本页
返回顶部