Pythonで並べ替える方法

DDD
リリース: 2023-08-29 14:54:36
オリジナル
3483 人が閲覧しました

Python のソート方法には、バブル ソート、選択ソート、挿入ソート、クイック ソート、マージ ソート、ヒープ ソート、基数ソートなどが含まれます。詳細な紹介: 1. バブル ソート、隣接する要素を比較し、それらの位置を交換することによってソート; 2. 選択ソート、リスト内の最小の要素を見つけてソート部分の最後に配置することによってソート; 3. 挿入ソート、次の条件でソートソートされた部分の適切な位置に各要素を挿入する; 4. クイックソート、分割統治法を使用してリストを小さなサブリストに分割するなど。

Pythonで並べ替える方法

このチュートリアルのオペレーティング システム: Windows 10 システム、Python バージョン 3.11.4、Dell G3 コンピューター。

Python は、データを並べ替えるためのさまざまな並べ替え方法を提供する強力なプログラミング言語です。この記事では、少なくとも 7 つの異なる並べ替え方法を詳細なコード例とともに取り上げます。

1. バブル ソート:

バブル ソートは、隣接する要素を比較し、その位置を交換することによってソートするシンプルなソート アルゴリズムです。スワップが発生しなくなるまで、リストを繰り返し処理します。

def bubble_sort(arr):
    n = len(arr)
    for i in range(n-1):
        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
ログイン後にコピー

2. 選択ソート:

選択ソートは、リスト内の最小の要素を見つけてソート部分に配置し、最後にソートする単純なソート アルゴリズムです。

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
ログイン後にコピー

3. 挿入ソート:

挿入ソートは、ソートされた部分の適切な位置に各要素を挿入することによってソートする単純なソート アルゴリズムです。

def insertion_sort(arr):
    n = len(arr)
    for i in range(1, n):
        key = arr[i]
        j = i-1
        while j >= 0 and arr[j] > key:
            arr[j+1] = arr[j]
            j -= 1
        arr[j+1] = key
    return arr
ログイン後にコピー

4. クイック ソート:

クイック ソートは、分割統治法を使用してリストを小さなサブリストに分割し、サブリストを再帰的に並べ替える効率的な並べ替えアルゴリズムです。

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)
ログイン後にコピー

5. マージ ソート:

マージ ソートは、分割統治法を使用してリストを小さなサブリストに分割し、再帰的にサブリストをソートして最後にマージする効率的なソート アルゴリズムです。それらを順序付きリストに追加します。

def merge_sort(arr):
    if len(arr) <= 1:
        return arr
    mid = len(arr) // 2
    left = arr[:mid]
    right = arr[mid:]
    left = merge_sort(left)
    right = merge_sort(right)
    return merge(left, right)
def merge(left, right):
    result = []
    i = j = 0
    while i < len(left) and j < len(right):
        if left[i] < right[j]:
            result.append(left[i])
            i += 1
        else:
            result.append(right[j])
            j += 1
    result.extend(left[i:])
    result.extend(right[j:])
    return result
ログイン後にコピー

6. ヒープ ソート:

ヒープ ソートは、ソートにバイナリ ヒープ データ構造を使用する効率的なソート アルゴリズムです。

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)
def heap_sort(arr):
    n = len(arr)
    for i in range(n//2 - 1, -1, -1):
        heapify(arr, n, i)
    for i in range(n-1, 0, -1):
        arr[i], arr[0] = arr[0], arr[i]
        heapify(arr, i, 0)
    return arr
ログイン後にコピー

7. 基数ソート:

基数ソートは、桁数に基づいて要素を並べ替える非比較並べ替えアルゴリズムです。

def counting_sort(arr, exp):
    n = len(arr)
    output = [0] * n
    count = [0] * 10
    for i in range(n):
        index = arr[i] // exp
        count[index % 10] += 1
    for i in range(1, 10):
        count[i] += count[i-1]
    i = n - 1
    while i >= 0:
        index = arr[i] // exp
        output[count[index % 10] - 1] = arr[i]
        count[index % 10] -= 1
        i -= 1
    for i in range(n):
        arr[i] = output[i]
def radix_sort(arr):
    max_val = max(arr)
    exp = 1
    while max_val // exp > 0:
        counting_sort(arr, exp)
        exp *= 10
    return arr
ログイン後にコピー

これは、7 つの異なる並べ替え方法の詳細なコード例です。さまざまなデータセットとパフォーマンス要件に応じて、適切な並べ替えアルゴリズムを選択すると、コードの効率とパフォーマンスを向上させることができます

以上がPythonで並べ替える方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート