ホームページ バックエンド開発 Python チュートリアル Pythonを使用してヒープソートアルゴリズムを実装するにはどうすればよいですか?

Pythonを使用してヒープソートアルゴリズムを実装するにはどうすればよいですか?

Sep 19, 2023 am 10:36 AM
Pythonヒープソートアルゴリズム

Pythonを使用してヒープソートアルゴリズムを実装するにはどうすればよいですか?

Python を使用してヒープ ソート アルゴリズムを実装するにはどうすればよいですか?

ヒープ ソートは、バイナリ ヒープに基づく並べ替えアルゴリズムであり、完全なバイナリ ツリーの特性を利用します。ヒープは、最大ヒープと最小ヒープの 2 つのタイプに分類できます。最大ヒープでは、親ノードの値がその子ノードの値以上である必要があり、最小ヒープでは、親ノードの値が必要です。はその子ノードの値以下です。ヒープソートアルゴリズムでは最大ヒープを使用します。

以下は、Python を使用してヒープ ソートを実装するための具体的な手順とコード例です。

ステップ 1: 最大ヒープを構築する
最大ヒープを構築するプロセスでは、次のことが必要です。各親ノードの値がその子ノードの値以上になるようにヒープ構造を調整します。

まず、ヒープ調整処理を実装する関数 heapify を定義します。この関数は、ヒープ リスト ヒープ、ヒープのサイズ、および調整する親ノードのインデックスの 3 つのパラメータを受け取ります。

def heapify(heap, size, parent):
    largest = parent
    left = 2 * parent + 1
    right = 2 * parent + 2

    if left < size and heap[left] > heap[largest]:
        largest = left

    if right < size and heap[right] > heap[largest]:
        largest = right

    if largest != parent:
        heap[parent], heap[largest] = heap[largest], heap[parent]
        heapify(heap, size, largest)
ログイン後にコピー

次に、最大ヒープを構築する関数 build_heap を定義します。この関数は引数としてリストを受け取り、リスト内の要素に基づいて最大ヒープを構築します。

def build_heap(heap):
    size = len(heap)

    for i in range(size // 2 - 1, -1, -1):
        heapify(heap, size, i)
ログイン後にコピー

ステップ 2: ヒープの並べ替え
最大ヒープを構築した後、最大ヒープのプロパティを並べ替えに使用できます。ヒープソートの考え方は、毎回ヒープの先頭要素(最大値)を最後の要素と交換し、ヒープの先頭を調整してから最大値を取り出し、残りの値だけになるまで再度調整することです。ヒープ内に 1 つの要素が残ります。

次に、ヒープ ソート アルゴリズムを使用してソートするための具体的な手順とコード例を示します。

def heap_sort(heap):
    size = len(heap)

    build_heap(heap)

    for i in range(size - 1, 0, -1):
        heap[0], heap[i] = heap[i], heap[0]
        heapify(heap, i, 0)
ログイン後にコピー

ステップ 3: コードをテストする
次に、いくつかのテスト データを使用して、次のことを確認します。私たちのコードは正しいです。

if __name__ == "__main__":
    # 测试数据
    data = [4, 10, 3, 5, 1]

    heap_sort(data)

    print("排序结果:", data)
ログイン後にコピー

上記のコードを実行すると、出力結果は次のようになります:sort result: [1, 3, 4, 5, 10]。ヒープ ソート アルゴリズムが正しいことを示します。

概要:
ヒープ ソートは、時間計算量が O(nlogn) の効率的なソート アルゴリズムです。ヒープの完全なバイナリ ツリーの特性を利用して、最大のヒープを構築し、ヒープの並べ替えを実行することでこれを実現できます。 Python 言語を使用すると、ヒープ調整関数 (heapify)、最大ヒープ構築関数 (build_heap)、およびヒープ ソート関数 (heap_sort) を記述することによって、ヒープ ソート アルゴリズムを実装できます。テストコードは、実装が正しいことを検証するのに役立ちます。

以上がPythonを使用してヒープソートアルゴリズムを実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

LinuxターミナルでPythonバージョンを表示するときに発生する権限の問題を解決する方法は? LinuxターミナルでPythonバージョンを表示するときに発生する権限の問題を解決する方法は? Apr 01, 2025 pm 05:09 PM

LinuxターミナルでPythonバージョンを表示する際の許可の問題の解決策PythonターミナルでPythonバージョンを表示しようとするとき、Pythonを入力してください...

あるデータフレームの列全体を、Python内の異なる構造を持つ別のデータフレームに効率的にコピーする方法は? あるデータフレームの列全体を、Python内の異なる構造を持つ別のデータフレームに効率的にコピーする方法は? Apr 01, 2025 pm 11:15 PM

PythonのPandasライブラリを使用する場合、異なる構造を持つ2つのデータフレーム間で列全体をコピーする方法は一般的な問題です。 2つのデータがあるとします...

プロジェクトの基本と問題駆動型の方法で10時間以内にコンピューター初心者プログラミングの基本を教える方法は? プロジェクトの基本と問題駆動型の方法で10時間以内にコンピューター初心者プログラミングの基本を教える方法は? Apr 02, 2025 am 07:18 AM

10時間以内にコンピューター初心者プログラミングの基本を教える方法は?コンピューター初心者にプログラミングの知識を教えるのに10時間しかない場合、何を教えることを選びますか...

中間の読書にどこでもfiddlerを使用するときにブラウザによって検出されないようにするにはどうすればよいですか? 中間の読書にどこでもfiddlerを使用するときにブラウザによって検出されないようにするにはどうすればよいですか? Apr 02, 2025 am 07:15 AM

fiddlereveryversings for the-middleの測定値を使用するときに検出されないようにする方法

正規表現とは何ですか? 正規表現とは何ですか? Mar 20, 2025 pm 06:25 PM

正規表現は、プログラミングにおけるパターンマッチングとテキスト操作のための強力なツールであり、さまざまなアプリケーションにわたるテキスト処理の効率を高めます。

uvicornは、serving_forever()なしでhttpリクエストをどのように継続的に聞いていますか? uvicornは、serving_forever()なしでhttpリクエストをどのように継続的に聞いていますか? Apr 01, 2025 pm 10:51 PM

UvicornはどのようにしてHTTPリクエストを継続的に聞きますか? Uvicornは、ASGIに基づく軽量のWebサーバーです。そのコア機能の1つは、HTTPリクエストを聞いて続行することです...

人気のあるPythonライブラリとその用途は何ですか? 人気のあるPythonライブラリとその用途は何ですか? Mar 21, 2025 pm 06:46 PM

この記事では、numpy、pandas、matplotlib、scikit-learn、tensorflow、django、flask、and requestsなどの人気のあるPythonライブラリについて説明し、科学的コンピューティング、データ分析、視覚化、機械学習、Web開発、Hの使用について説明します。

文字列を介してオブジェクトを動的に作成し、Pythonでメソッドを呼び出す方法は? 文字列を介してオブジェクトを動的に作成し、Pythonでメソッドを呼び出す方法は? Apr 01, 2025 pm 11:18 PM

Pythonでは、文字列を介してオブジェクトを動的に作成し、そのメソッドを呼び出す方法は?これは一般的なプログラミング要件です。特に構成または実行する必要がある場合は...

See all articles