ホームページ バックエンド開発 C++ C++ で基数ソート アルゴリズムを使用する方法

C++ で基数ソート アルゴリズムを使用する方法

Sep 19, 2023 pm 12:15 PM
c++ ソートアルゴリズム 基数ソート

C++ で基数ソート アルゴリズムを使用する方法

C で基数並べ替えアルゴリズムを使用する方法

基数並べ替えアルゴリズムは、並べ替え対象の要素を有限の桁のセットに分割する非比較並べ替えアルゴリズムです。並べ替えを完了します。 C では、基数ソート アルゴリズムを使用して整数のセットをソートできます。以下では、特定のコード例を使用して、基数ソート アルゴリズムを実装する方法を詳しく説明します。

  1. アルゴリズムのアイデア
    基数ソート アルゴリズムのアイデアは、ソート対象の要素を限られたデジタル ビットのセットに分割し、各ビットで順番に要素をソートすることです。各ビットのソートが完了すると、そのビットの順序に従って要素が再編成され、すべてのビットがソートされるまで次のビットのソートが続けられます。
  2. 具体的な実装手順
    (1) まず、ソート対象となる全要素の最大値の桁数を決定する必要があります。これにより、ソートを何ラウンド行う必要があるかが決まります。

(2) 次に、補助配列とカウント配列を作成する必要があります。補助配列は並べ替え処理中に一時的な結果を保存するために使用され、計数配列は各数値の出現回数を記録するために使用されます。

(3) 次に、複数回の並べ替えを実行する必要があります。ソートの各ラウンドでは、現在のビット サイズに従って配列が再編成されます。

(4) ソートの各ラウンドでは、ソート対象の配列を走査し、各要素の現在のビット値をインデックスとして使用し、要素を対応するバケットに入れる必要があります。

(5) 次に、各バケット内の要素の数をカウントする必要があります。これは、カウント配列を使用して記録できます。

(6) 次に、配列を数えることによって、補助配列内の各バケット内の要素の位置を決定する必要があります。これは、配列内の要素のプレフィックスの合計をカウントすることで判断できます。

(7) 最後に、補助配列の要素をソート対象の配列に上書きして、一連のソートを完了します。

(8) すべてのビットがソートされるまで、手順 (3) ~ (7) を繰り返します。

  1. コード例
    次は、C を使用して基数ソート アルゴリズムを実装するコード例です。
#include <iostream>
#include <vector>

using namespace std;

void radixSort(vector<int>& arr) {
    int maxVal = *max_element(arr.begin(), arr.end());

    int digit = 1;
    vector<int> temp(arr.size());
    while (maxVal / digit > 0) {
        vector<int> count(10, 0);

        for (int i = 0; i < arr.size(); i++) {
            count[(arr[i] / digit) % 10]++;
        }

        for (int i = 1; i < 10; i++) {
            count[i] += count[i - 1];
        }

        for (int i = arr.size() - 1; i >= 0; i--) {
            temp[count[(arr[i] / digit) % 10] - 1] = arr[i];
            count[(arr[i] / digit) % 10]--;
        }

        for (int i = 0; i < arr.size(); i++) {
            arr[i] = temp[i];
        }

        digit *= 10;
    }
}

int main() {
    vector<int> arr = { 170, 45, 75, 90, 802, 24, 2, 66 };
    radixSort(arr);

    cout << "排序结果:";
    for (int i = 0; i < arr.size(); i++) {
        cout << arr[i] << " ";
    }
    cout << endl;

    return 0;
}
ログイン後にコピー

上記のコード例では、まず、ソートされる配列 何ラウンドのソートが必要かを決定する最大値。次に、補助配列とカウント配列を作成しました。次に、複数回のソートを実行して、現在のビット サイズに従って配列を再構成します。最後に、ソートした結果を出力します。

要約:
基数ソート アルゴリズムを通じて、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++ で戦略デザイン パターンを実装するにはどうすればよいですか? C++ で戦略デザイン パターンを実装するにはどうすればよいですか? Jun 06, 2024 pm 04:16 PM

C++ でストラテジ パターンを実装する手順は次のとおりです。ストラテジ インターフェイスを定義し、実行する必要があるメソッドを宣言します。特定の戦略クラスを作成し、それぞれインターフェイスを実装し、さまざまなアルゴリズムを提供します。コンテキスト クラスを使用して、具体的な戦略クラスへの参照を保持し、それを通じて操作を実行します。

Golang と C++ の類似点と相違点 Golang と C++ の類似点と相違点 Jun 05, 2024 pm 06:12 PM

Golang と C++ は、それぞれガベージ コレクションと手動メモリ管理のプログラミング言語であり、構文と型システムが異なります。 Golang は Goroutine を通じて同時プログラミングを実装し、C++ はスレッドを通じて同時プログラミングを実装します。 Golang のメモリ管理はシンプルで、C++ の方がパフォーマンスが優れています。実際の場合、Golang コードはより簡潔であり、C++ には明らかにパフォーマンス上の利点があります。

C++ でネストされた例外処理を実装するにはどうすればよいですか? C++ でネストされた例外処理を実装するにはどうすればよいですか? Jun 05, 2024 pm 09:15 PM

ネストされた例外処理は、ネストされた try-catch ブロックを通じて C++ に実装され、例外ハンドラー内で新しい例外を発生させることができます。ネストされた try-catch ステップは次のとおりです。 1. 外側の try-catch ブロックは、内側の例外ハンドラーによってスローされた例外を含むすべての例外を処理します。 2. 内部の try-catch ブロックは特定のタイプの例外を処理し、スコープ外の例外が発生した場合、制御は外部例外ハンドラーに渡されます。

C++ STL コンテナを反復するにはどうすればよいですか? C++ STL コンテナを反復するにはどうすればよいですか? Jun 05, 2024 pm 06:29 PM

STL コンテナを反復するには、コンテナの begin() 関数と end() 関数を使用してイテレータ範囲を取得できます。 ベクトル: for ループを使用してイテレータ範囲を反復します。リンク リスト: next() メンバー関数を使用して、リンク リストの要素を移動します。マッピング: キーと値のイテレータを取得し、for ループを使用してそれを走査します。

C++ テンプレートの継承を使用するにはどうすればよいですか? C++ テンプレートの継承を使用するにはどうすればよいですか? Jun 06, 2024 am 10:33 AM

C++ テンプレートの継承により、テンプレート派生クラスが基本クラス テンプレートのコードと機能を再利用できるようになり、コア ロジックは同じだが特定の動作が異なるクラスを作成するのに適しています。テンプレート継承の構文は次のとおりです: templateclassDerived:publicBase{}。例: templateclassBase{};templateclassDerived:publicBase{};。実際のケース: 派生クラス Derived を作成し、基本クラス Base のカウント関数を継承し、現在のカウントを出力する printCount メソッドを追加しました。

Docker環境にPECLを使用して拡張機能をインストールするときにエラーが発生するのはなぜですか?それを解決する方法は? Docker環境にPECLを使用して拡張機能をインストールするときにエラーが発生するのはなぜですか?それを解決する方法は? Apr 01, 2025 pm 03:06 PM

エラーの原因とソリューションPECLを使用してDocker環境に拡張機能をインストールする場合、Docker環境を使用するときに、いくつかの頭痛に遭遇します...

C文字列におけるcharの役割は何ですか C文字列におけるcharの役割は何ですか Apr 03, 2025 pm 03:15 PM

Cでは、文字列でCharタイプが使用されます。1。単一の文字を保存します。 2。配列を使用して文字列を表し、ヌルターミネーターで終了します。 3。文字列操作関数を介して動作します。 4.キーボードから文字列を読み取りまたは出力します。

クロススレッド C++ 例外を処理するにはどうすればよいですか? クロススレッド C++ 例外を処理するにはどうすればよいですか? Jun 06, 2024 am 10:44 AM

マルチスレッド C++ では、例外処理は std::promise および std::future メカニズムを通じて実装されます。promise オブジェクトを使用して、例外をスローするスレッドで例外を記録します。 future オブジェクトを使用して、例外を受信するスレッドで例外を確認します。実際のケースでは、Promise と Future を使用して、さまざまなスレッドで例外をキャッチして処理する方法を示します。

See all articles