ホームページ バックエンド開発 C#.Net チュートリアル C# を使用してヒープ ソート アルゴリズムを作成する方法

C# を使用してヒープ ソート アルゴリズムを作成する方法

Sep 19, 2023 am 08:45 AM
書く c# ヒープソート

C# を使用してヒープ ソート アルゴリズムを作成する方法

C# を使用してヒープ ソート アルゴリズムを作成する方法

ヒープ ソート (ヒープ ソート) は、完全なバイナリ ヒープに基づくソート アルゴリズムであり、その時間計算量はああ(んろぐん)。この記事では、C# を使用してヒープ ソート アルゴリズムを作成し、詳細なコード例を示します。

  1. ヒープの構築

ヒープ ソート アルゴリズムでは、まず最大ヒープ (または最小ヒープ) を構築する必要があります。最大ヒープの特性は、親ノードの値がその子ノードの値以上であるのに対し、最小ヒープの場合はその逆です。

最大のヒープを構築するには、配列を使用してヒープを表現します。ヒープのノードは階層順に配置されます。ノード インデックス i が与えられると、次の方法でその親ノードと子ノードのインデックスを見つけることができます:

  • 親ノード インデックス = (i - 1) / 2
  • 左子ノード インデックス = 2 * i 1
  • 右側の子ノードのインデックス = 2 * i 2

これらのインデックスを使用すると、ヒープ内を簡単に移動し、大きく (または小さく) 移動できます。要素はプッシュされます。ヒープの一番上まで。

次は、C# を使用して最大ヒープを実装するサンプル コードです:

public void BuildMaxHeap(int[] arr, int n, int i)
{
    int largest = i; // 初始化最大元素的索引
    int left = 2 * i + 1; // 左子节点索引
    int right = 2 * i + 2; // 右子节点索引

    // 如果左子节点比父节点大,更新最大元素的索引
    if (left < n && arr[left] > arr[largest])
    {
        largest = left;
    }

    // 如果右子节点比父节点大,更新最大元素的索引
    if (right < n && arr[right] > arr[largest])
    {
        largest = right;
    }

    // 如果最大元素的索引不是父节点的索引,交换父节点和最大元素
    if (largest != i)
    {
        int temp = arr[i];
        arr[i] = arr[largest];
        arr[largest] = temp;

        // 递归地建立最大堆
        BuildMaxHeap(arr, n, largest);
    }
}
ログイン後にコピー
  1. Heap sort

最大ヒープを構築した後、次を使用できます。 heap sort 配列をソートするアルゴリズム。ヒープソートの考え方は、最大の要素を配列の末尾に連続的に交換し、ソートする配列の範囲を減らすことです。具体的な手順は次のとおりです。

  • 最大ヒープを構築します
  • ヒープの先頭要素と最後の要素を交換します
  • ヒープを再調整します
  • ソートされた配列に要素が 1 つだけ残るまで、上記の手順を繰り返します。
#次は、C# を使用してヒープ ソートを実装するサンプル コードです。

public void HeapSort(int[] arr)
{
    int n = arr.Length;

    // 构建最大堆
    for (int i = n / 2 - 1; i >= 0; i--)
    {
        BuildMaxHeap(arr, n, i);
    }

    // 交换堆顶元素和末尾元素,并重建最大堆
    for (int i = n - 1; i > 0; i--)
    {
        int temp = arr[0];
        arr[0] = arr[i];
        arr[i] = temp;

        BuildMaxHeap(arr, i, 0);
    }
}
ログイン後にコピー

    テスト コード
For ヒープ ソート アルゴリズムが正しいことを検証するには、ランダムに生成された配列をソートし、チェックする結果を出力するテスト コードを作成します。以下は、C# で書かれたヒープ ソート テスト コードの例です。

int[] arr = { 12, 11, 13, 5, 6, 7 };
HeapSort(arr);

Console.WriteLine("排序后的数组:");
foreach (var element in arr)
{
    Console.Write(element + " ");
}
ログイン後にコピー
    概要
上記の手順により、C# を使用してヒープ ソート アルゴリズムを正常に作成できました。詳細なコード例が提供されます。ヒープ ソートは、ほとんどの場合に優れたパフォーマンスを提供する効率的なソート アルゴリズムです。この記事がヒープ ソート アルゴリズムの理解と実装に役立つことを願っています。

以上がC# を使用してヒープ ソート アルゴリズムを作成する方法の詳細内容です。詳細については、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)

C# を使用した Active Directory C# を使用した Active Directory Sep 03, 2024 pm 03:33 PM

C# を使用した Active Directory のガイド。ここでは、Active Directory の概要と、C# での動作方法について、構文と例とともに説明します。

C# の乱数ジェネレーター C# の乱数ジェネレーター Sep 03, 2024 pm 03:34 PM

C# の乱数ジェネレーターのガイド。ここでは、乱数ジェネレーターの仕組み、擬似乱数の概念、安全な数値について説明します。

C# のアクセス修飾子 C# のアクセス修飾子 Sep 03, 2024 pm 03:24 PM

C# のアクセス修飾子のガイド。 C# のアクセス修飾子の種類について、例と出力とともに説明しました。

C# シリアル化 C# シリアル化 Sep 03, 2024 pm 03:30 PM

C# シリアル化のガイド。ここでは、C# シリアル化オブジェクトの導入、手順、作業、例についてそれぞれ説明します。

C# データ グリッド ビュー C# データ グリッド ビュー Sep 03, 2024 pm 03:32 PM

C# データ グリッド ビューのガイド。ここでは、SQL データベースまたは Excel ファイルからデータ グリッド ビューをロードおよびエクスポートする方法の例について説明します。

C# のパターン C# のパターン Sep 03, 2024 pm 03:33 PM

C# のパターンのガイド。ここでは、C# のパターンの概要と上位 3 種類について、その例とコード実装とともに説明します。

C# の素数 C# の素数 Sep 03, 2024 pm 03:35 PM

C# の素数ガイド。ここでは、C# における素数の導入と例を、コードの実装とともに説明します。

C# の階乗 C# の階乗 Sep 03, 2024 pm 03:34 PM

C# の Factorial のガイド。ここでは、C# での階乗の概要について、さまざまな例とコード実装とともに説明します。

See all articles