Python中實現列表排序 – 提高數據展示質量

一、排序算法介紹

排序是程序中一個非常重要的操作,它將一組數據按照一定的規則進行排列, 方便快速查找。在Python中,可用的排序算法很多,我們着重介紹以下幾種:

1. 冒泡排序: 每次比較相鄰兩個元素的大小,如果第一個比第二個大,則交換它們的位置。時間複雜度為O(n^2)。

<?php
def bubble_sort(arr):
    n = len(arr)
    for i in range(n):
        for j in range(n-i-1):
            if arr[j] > arr[j+1]:
                arr[j], arr[j+1] = arr[j+1], arr[j]
    return arr
print(bubble_sort([4,2,1,5,3])) ?>

2. 插入排序: 將未排序的數插入到已經排序的數中,每次比較要插入數的大小和已經排序好的數的大小。時間複雜度為O(n^2)。

<?php
def insert_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
print(insert_sort([4,2,1,5,3])) ?>

3. 快速排序: 以一個基準數為參照物,將小於等於它的數放在左邊,大於它的數放在右邊。時間複雜度為O(nlogn)。

<?php
def quick_sort(arr):
    if len(arr) < 2:
        return arr
    pivot = arr[0] # 基準值
    less = [i for i in arr[1:] if i  pivot]
    return quick_sort(less) + [pivot] + quick_sort(greater)
print(quick_sort([4,2,1,5,3])) ?>

二、Python內置排序函數sorted()

Python內置函數sorted()可以對列表進行高效排序,同時支持自定義排序規則、多關鍵字排序、倒序排序等功能。下面給出幾個示例。

1. 對列表進行默認升序排序。

<?php
arr = [4,2,1,5,3]
print(sorted(arr)) # [1, 2, 3, 4, 5]
?>

2. 對列表進行倒序排序。

<?php
arr = [4,2,1,5,3]
print(sorted(arr, reverse=True)) # [5, 4, 3, 2, 1]
?>

3. 對列表中每個元素的絕對值進行升序排序。

<?php
arr = [4,-2,1,-5,3]
print(sorted(arr, key=abs)) # [1, -2, 3, 4, -5]
?>

4. 對學生成績列表進行按照成績降序排序,並且如果成績相同,則按照學號升序排序。

<?php
students = [('Alice', 80, 2), ('Bob', 90, 1), ('Chris', 80, 3)]
print(sorted(students, key=lambda x: (-x[1], x[2]))) # [('Bob', 90, 1), ('Alice', 80, 2), ('Chris', 80, 3)]
?>

三、NumPy中的排序函數

NumPy是Python中一個科學計算的庫,提供了許多強大的函數和工具,包括數組計算、數學函數、線性代數、隨機數生成、傅里葉變換等等。下面介紹NumPy中的多種排序函數。

1. sort()函數:返回排序後的新數組。

<?php
import numpy as np
arr = np.array([4,2,1,5,3])
print(np.sort(arr)) # [1 2 3 4 5]
?>

2. argsort()函數:返回排序後的每個元素(在原數組中的下標)組成的新數組。

<?php
import numpy as np
arr = np.array([4,2,1,5,3])
print(np.argsort(arr)) # [2 1 4 0 3]
?>

3. lexsort()函數:對多維數組進行排序,返回排序後元素的下標組成的新數組。

<?php
import numpy as np
nm = ('Tom', 'Dick', 'Harry') 
stud = np.zeros(3, dtype={'names':('name', 'height', 'age'), 'formats':('U10', 'f8', 'i4')}) 
stud['name'] = nm
stud['height'] = [5.5, 6.0, 5.75]
stud['age'] = [22, 21, 19]
print(np.lexsort((stud['name'], stud['age'], stud['height']))) # [2 1 0]
?>

四、Pandas中的排序函數

Pandas是Python中一個數據處理的庫,提供了高效、靈活、易用的數據結構和數據分析工具。下面介紹Pandas中的兩種排序函數。

1. sort_values()函數:按照指定列或行進行排序。

<?php
import pandas as pd
df = pd.DataFrame({'name': ['Alice', 'Bob', 'Chris'], 'score': [90, 60, 70], 'age': [20, 22, 21]})
print(df.sort_values(by='score')) #   name  score  age
                                   # 1   Bob     60   22
                                   # 2 Chris     70   21
                                   # 0 Alice     90   20
?>

2. sort_index()函數:按照行或列的索引進行排序。

<?php
import pandas as pd
df = pd.DataFrame({'name': ['Alice', 'Bob', 'Chris'], 'score': [90, 60, 70], 'age': [20, 22, 21]})
print(df.sort_index(axis=1)) #    age   name  score
                             # 0   20  Alice     90
                             # 1   22    Bob     60
                             # 2   21  Chris     70
?>

五、總結

在Python中,我們可以使用多種內置的排序函數,也可以調用第三方庫中強大的排序工具,以滿足不同的排序需求。對於大規模數據的排序,應選擇時間複雜度較小的快速排序算法;對於元素包含多個關鍵字的數據結構,應調用支持多關鍵字排序的函數;對於需要處理二維及以上的數據結構,應使用Pandas中的函數。總之,數據排序是非常基礎的數據操作,合理使用各種工具可以大幅提高程序的效率以及數據的可讀性。

原創文章,作者:AYBR,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/138123.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
AYBR的頭像AYBR
上一篇 2024-10-04 00:18
下一篇 2024-10-04 00:18

相關推薦

  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • Python清華鏡像下載

    Python清華鏡像是一個高質量的Python開發資源鏡像站,提供了Python及其相關的開發工具、框架和文檔的下載服務。本文將從以下幾個方面對Python清華鏡像下載進行詳細的闡…

    編程 2025-04-29
  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • 蝴蝶優化算法Python版

    蝴蝶優化算法是一種基於仿生學的優化算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化算法Python版…

    編程 2025-04-29
  • python強行終止程序快捷鍵

    本文將從多個方面對python強行終止程序快捷鍵進行詳細闡述,並提供相應代碼示例。 一、Ctrl+C快捷鍵 Ctrl+C快捷鍵是在終端中經常用來強行終止運行的程序。當你在終端中運行…

    編程 2025-04-29

發表回復

登錄後才能評論