目次
ソートアルゴリズムの安定性と重要性
バブルソート
複雑さと安定性
選択ソート
挿入ソート
ヒルソート
クイックソート
一般的な並べ替えアルゴリズムの効率の比較
ホームページ バックエンド開発 Python チュートリアル Python でよく使用される並べ替えの例を共有する

Python でよく使用される並べ替えの例を共有する

Jun 21, 2017 pm 04:40 PM
python 選別

  • ソートアルゴリズムの安定性と重要性

  • バブルソート

    • 複雑さと安定性

  • 選択ソート

  • 挿入ソート

  • ヒルソート

  • クイックソート

  • 一般的なソートアルゴリズムの効率の比較

ソートアルゴリズムの安定性と重要性

ソート対象のシーケンス内に、同じキーワードを持つレコードがあり、ソート後もこれらのレコードの相対的な順序は変化しません。ソートアルゴリズムは安定しています。

並べ替えが不安定なので、複数のキーワードの並べ替えを完了できません。たとえば、整数の並べ替えでは、桁数が多いほど優先順位が高く、上位の桁から下位の桁へ並べ替えられます。したがって、各ビットのソートには安定したアルゴリズムが必要であり、そうでないと正しい結果が得られません。

つまり、 複数のキーワードを複数回ソートしたい場合は、安定したアルゴリズムを使用する必要があります

バブルソート

Screen Shot 2017-06-11 at 10.23.12 A

def bubble_sort(alist):
    """
    冒泡排序
    """
    if len(alist) <= 1:
        return alist

    for j in range(len(alist)-1,0,-1):
        for i in range(j):
            if alist[i] > alist[i+1]:
                alist[i], alist[i+1] = alist[i+1], alist[i]

    return alist
ログイン後にコピー

複雑さと安定性

  • 最適な時間計算量: ( O(n) ) 走査では交換できる要素が見つからず、ソートが終了します

  • 最悪の時間計算量: (O(n^2))

  • 安定性: 安定しています

選択ソート

選択ソートはシンプルで直感的な並べ替えアルゴリズム。仕組みは次のとおりです。まず、ソートされていないシーケンス内で最小の (大きい) 要素を見つけて、ソートされたシーケンスの先頭に格納します。次に、ソートされていない残りの要素から最小の (大きい) 要素を見つけて、それをソートされたシーケンスの最後に置きます。ソートされたシーケンス。すべての要素がソートされるまで続きます。

挿入ソート

挿入ソートは、並べ替えられていないデータの場合、並べ替えられたシーケンスの後ろから前に向かってスキャンして、対応する位置を見つけて挿入します。挿入ソートの実装では、後ろから前へのスキャン プロセス中に、最新の要素に挿入スペースを提供するために、ソートされた要素を繰り返し徐々に後方に移動する必要があります。

Screen Shot 2017-06-12 at 7.07.03 P

def insert_sort(alist):
    """
    插入排序
    """
    n = len(alist)
    if n <= 1:
        return alist

    # 从第二个位置,即下表为1的元素开始向前插入
    for i in range(1, n):
        j = i
        # 向前向前比较,如果小于前一个元素,交换两个元素
        while alist[j] < alist[j-1] and j > 0:
            alist[j], alist[j-1] = alist[j-1], alist[j]
            j-=1
    return alist
ログイン後にコピー

複雑さと安定性

  • 最適な時間計算量: O((n)) (昇順に並べられており、シーケンスはすでに昇順になっています)

  • 最悪の時間計算量: O( (n ^2))

  • 安定性: 安定

ヒルソート

ヒルソート(シェルソート)は挿入ソートを改良したものであり、ソートは安定していません。ヒルソートでは、添字の特定の増分でレコードをグループ化し、直接挿入ソートアルゴリズムを使用して各グループをソートします。増分が徐々に減少するにつれて、各グループにはさらに多くのキーワードが含まれます。今度は、ファイル全体が 1 つのグループに分割され、アルゴリズムが終了します。

def shell_sort(alist):
    
    n = len(alist)
    gap = n//2
    
    # gap 变化到0之前,插入算法之行的次数
    while gap > 0:
        
        # 希尔排序, 与普通的插入算法的区别就是gap步长
        for i in range(gap,n):
            j = i
            while alist[j] < alist[j-gap] and j > 0:
                alist[j], alist[j-gap] = alist[j-gap], alist[j]
                j-=gap
    
        gap = gap//2

    return alist
ログイン後にコピー

複雑さと安定性

  • 最適な時間計算量: (O(n^{1.3})) (注文する必要はありません)

  • 最悪の時間計算量: (O(n^) 2))

  • 安定性: 不安定

クイックソート

クイックソート(クイックソート)は、一度のソートでソート対象のデータを2つの独立した部分に分割し、一方の部分のすべてのデータが他方の部分よりも優れている必要があります。次に、このメソッドを使用してデータの 2 つの部分をそれぞれすばやく並べ替えます。並べ替えプロセス全体を再帰的に実行できるため、データ全体が順序付けされたシーケンスになります。

手順は次のとおりです:

  1. シーケンスから「ピボット」と呼ばれる要素を選択します

  2. シーケンスを並べ替えます。ピボット値より小さいすべての要素がピボットの前に配置され、ピボット値より小さいすべての要素が配置されます。ピボット値はピボットの前に配置されます。より大きな値を持つ値はベースの後ろに配置されます (同じ数値をどちらの側にも置くことができます)。この分割の後、データはシーケンスの途中にあります。これをパーティション操作と呼びます。

  3. 基本値より小さい要素の部分配列と基本値より大きい要素の部分配列を再帰的に並べ替えます。

再帰の最も低いケースは、配列のサイズが 0 または 1 の場合、つまり、配列が常にソートされている場合です。再帰は続けられますが、各反復 (反復) で少なくとも 1 つの要素が最終位置に移動するため、このアルゴリズムは常に終了します。

一般的な並べ替えアルゴリズムの効率の比較

以上が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)

XMLをPDFに変換できるモバイルアプリはありますか? XMLをPDFに変換できるモバイルアプリはありますか? Apr 02, 2025 pm 08:54 PM

XMLをPDFに直接変換するアプリケーションは、2つの根本的に異なる形式であるため、見つかりません。 XMLはデータの保存に使用され、PDFはドキュメントを表示するために使用されます。変換を完了するには、PythonやReportLabなどのプログラミング言語とライブラリを使用して、XMLデータを解析してPDFドキュメントを生成できます。

携帯電話でXMLをPDFに変換するとき、変換速度は高速ですか? 携帯電話でXMLをPDFに変換するとき、変換速度は高速ですか? Apr 02, 2025 pm 10:09 PM

Mobile XMLからPDFへの速度は、次の要因に依存します。XML構造の複雑さです。モバイルハードウェア構成変換方法(ライブラリ、アルゴリズム)コードの品質最適化方法(効率的なライブラリ、アルゴリズムの最適化、キャッシュデータ、およびマルチスレッドの利用)。全体として、絶対的な答えはなく、特定の状況に従って最適化する必要があります。

XMLをPDFに変換できるモバイルアプリはありますか? XMLをPDFに変換できるモバイルアプリはありますか? Apr 02, 2025 pm 09:45 PM

XML構造が柔軟で多様であるため、すべてのXMLファイルをPDFSに変換できるアプリはありません。 XMLのPDFへのコアは、データ構造をページレイアウトに変換することです。これには、XMLの解析とPDFの生成が必要です。一般的な方法には、ElementTreeなどのPythonライブラリを使用してXMLを解析し、ReportLabライブラリを使用してPDFを生成することが含まれます。複雑なXMLの場合、XSLT変換構造を使用する必要がある場合があります。パフォーマンスを最適化するときは、マルチスレッドまたはマルチプロセスの使用を検討し、適切なライブラリを選択します。

XMLを画像に変換するプロセスは何ですか? XMLを画像に変換するプロセスは何ですか? Apr 02, 2025 pm 08:24 PM

XML画像を変換するには、最初にXMLデータ構造を決定し、次に適切なグラフィカルライブラリ(PythonのMatplotlibなど)とメソッドを選択し、データ構造に基づいて視覚化戦略を選択し、データのボリュームと画像形式を検討し、バッチ処理を実行するか、効率的なライブラリを使用して、最終的にPNG、JPEG、またはSVGに応じて保存します。

携帯電話のXMLファイルをPDFに変換する方法は? 携帯電話のXMLファイルをPDFに変換する方法は? Apr 02, 2025 pm 10:12 PM

単一のアプリケーションで携帯電話でXMLからPDF変換を直接完了することは不可能です。クラウドサービスを使用する必要があります。クラウドサービスは、2つのステップで達成できます。1。XMLをクラウド内のPDFに変換し、2。携帯電話の変換されたPDFファイルにアクセスまたはダウンロードします。

画像に変換されたXMLのサイズを制御する方法は? 画像に変換されたXMLのサイズを制御する方法は? Apr 02, 2025 pm 07:24 PM

XMLを介して画像を生成するには、XMLのメタデータ(サイズ、色)に基づいて画像を生成するために、ブリッジとしてグラフライブラリ(枕やJFreechartなど)を使用する必要があります。画像のサイズを制御するための鍵は、&lt; width&gt;の値を調整することです。および&lt; height&gt; XMLのタグ。ただし、実際のアプリケーションでは、XML構造の複雑さ、グラフ描画の細かさ、画像生成の速度とメモリ消費の速度、および画像形式の選択はすべて、生成された画像サイズに影響を与えます。したがって、グラフィックライブラリに熟練したXML構造を深く理解し、最適化アルゴリズムや画像形式の選択などの要因を考慮する必要があります。

XML形式を開く方法 XML形式を開く方法 Apr 02, 2025 pm 09:00 PM

ほとんどのテキストエディターを使用して、XMLファイルを開きます。より直感的なツリーディスプレイが必要な場合は、酸素XMLエディターやXMLSPYなどのXMLエディターを使用できます。プログラムでXMLデータを処理する場合、プログラミング言語(Pythonなど)やXMLライブラリ(XML.ETREE.ELEMENTTREEなど)を使用して解析する必要があります。

XML形式を美化する方法 XML形式を美化する方法 Apr 02, 2025 pm 09:57 PM

XMLの美化は、合理的なインデンテーション、ラインブレーク、タグ組織など、本質的に読みやすさを向上させています。原則は、XMLツリーを通過し、レベルに応じてインデントを追加し、テキストを含む空のタグとタグを処理することです。 PythonのXML.ETREE.ELEMENTTREEライブラリは、上記の美化プロセスを実装できる便利なchile_xml()関数を提供します。

See all articles