検索
ホームページJava&#&チュートリアルJava Quick Sort の効率とパフォーマンスの評価

Java Quick Sort の効率とパフォーマンスの評価

Feb 19, 2024 pm 10:16 PM
パフォーマンス比較するクイックソートバブルソート

Java Quick Sort の効率とパフォーマンスの評価

Java Quick Sort のパフォーマンス分析と比較

Quick Sort (クイック ソート) は、実行速度が速く、パフォーマンスが優れているため、比較ベースの並べ替えアルゴリズムです。実際の開発でも広く使われています。この記事では、Java のクイック ソート アルゴリズムのパフォーマンス分析を実行し、他の一般的なソート アルゴリズムと比較します。

  1. クイックソートアルゴリズムの原理
    クイックソートは分割統治法の考え方を採用しており、ソート対象のデータを2つの独立した部分に分割することで、左側と右側の部分列をそれぞれ再帰的にソートします。を達成するために、シーケンス全体が順序付けされます。具体的なアルゴリズムの手順は次のとおりです。
    1) 配列から軸の値 (ピボット) を選択します。通常は配列の最初の要素です。
    2) 1 回のソートパスで配列を左と右のサブシーケンスに分割し、左のサブシーケンスの要素が軸の値以下になり、右のサブシーケンスの要素が軸の値より大きくなります。 。
    3) シーケンスの長さが 1 または 0 になるまで、左と右のサブシーケンスを再帰的にクイック ソートします。
    4) 最後にソートされたシーケンスを取得します。
  2. Java でのクイック ソートの実装
    Java でクイック ソートを実装するためのサンプル コードを次に示します:
public class QuickSort {
  public static void quickSort(int[] arr, int low, int high) {
    if (low < high) {
      int pivotIdx = partition(arr, low, high);
      quickSort(arr, low, pivotIdx - 1);
      quickSort(arr, pivotIdx + 1, high);
    }
  }
  
  private static int partition(int[] arr, int low, int high) {
    int pivot = arr[low];
    int i = low + 1;
    int j = high;
    
    while (i <= j) {
      if (arr[i] <= pivot) {
        i++;
      } else if (arr[j] > pivot) {
        j--;
      } else {
        swap(arr, i, j);
      }
    }
    
    swap(arr, low, j);
    
    return j;
  }
  
  private static void swap(int[] arr, int i, int j) {
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
  }
  
  public static void main(String[] args) {
    int[] arr = {5, 2, 9, 1, 3, 7};
    quickSort(arr, 0, arr.length - 1);
    System.out.println(Arrays.toString(arr));
  }
}
  1. パフォーマンス分析と比較
    クイックソートの評価 アルゴリズムのパフォーマンスを、他のいくつかの一般的なソートアルゴリズムと比較します。以下は、Java の System.nanoTime() メソッドを使用してアルゴリズムの実行時間を計算するサンプル コードです。
import java.util.Arrays;

public class SortComparison {
  public static void main(String[] args) {
    int[] arr = generateArray(10000);
    
    long startTime = System.nanoTime();
    bubbleSort(arr.clone());
    long endTime = System.nanoTime();
    System.out.println("Bubble Sort: " + (endTime - startTime) + " ns");
    
    startTime = System.nanoTime();
    insertionSort(arr.clone());
    endTime = System.nanoTime();
    System.out.println("Insertion Sort: " + (endTime - startTime) + " ns");
    
    startTime = System.nanoTime();
    selectionSort(arr.clone());
    endTime = System.nanoTime();
    System.out.println("Selection Sort: " + (endTime - startTime) + " ns");
    
    startTime = System.nanoTime();
    quickSort(arr.clone(), 0, arr.length - 1);
    endTime = System.nanoTime();
    System.out.println("Quick Sort: " + (endTime - startTime) + " ns");
  }
  
  private static int[] generateArray(int size) {
    int[] arr = new int[size];
    for (int i = 0; i < size; i++) {
      arr[i] = (int)(Math.random() * size);
    }
    return arr;
  }
  
  private static void bubbleSort(int[] arr) {
    // 省略冒泡排序的具体实现
  }
  
  private static void insertionSort(int[] arr) {
    // 省略插入排序的具体实现
  }
  
  private static void selectionSort(int[] arr) {
    // 省略选择排序的具体实现
  }
  
  private static void quickSort(int[] arr, int low, int high) {
    // 省略快速排序的具体实现
  }
}

上記のコードを実行すると、次のコードを実行できます。各ソートアルゴリズム時間。実験結果によると、クイック ソート アルゴリズムは一般に、特に大規模なデータ セットをソートする場合、バブル ソート、挿入ソート、選択ソートよりも高速です。もちろん、特定のケースでは、他の並べ替えアルゴリズムのパフォーマンスが優れている場合があるため、特定の問題の具体的な分析が実行され、実際の状況に基づいて最適な並べ替えアルゴリズムが選択されます。

概要:
この記事では、Java のクイック ソート アルゴリズムのパフォーマンス分析を実行し、他の一般的なソート アルゴリズムと比較します。実験結果から、クイック ソートは一般に効率的なソート アルゴリズムであり、特に大規模なデータ セットのソートに適していると結論付けることができます。ただし、特定の問題については、実際の状況に基づいて最適な並べ替えアルゴリズムを選択する必要があります。

以上がJava Quick Sort の効率とパフォーマンスの評価の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Apacheの.htaccess構成をNginxの構成に変換する方法は?Apacheの.htaccess構成をNginxの構成に変換する方法は?Apr 19, 2025 pm 05:09 PM

Apacheの.htaccess構成をプロジェクト開発でnginxに変換するための構成方法では、サーバーをApacheからNginxに移行する必要がある状況に遭遇することがよくあります。 AP ...

小規模なJavawebアプリケーションでは、DAOレイヤーがすべての人事エンティティクラスをキャッシュすることは実行可能ですか?小規模なJavawebアプリケーションでは、DAOレイヤーがすべての人事エンティティクラスをキャッシュすることは実行可能ですか?Apr 19, 2025 pm 05:06 PM

Javawebアプリケーションパフォーマンスの最適化:Javawebアプリケーション開発におけるDAOレベルのエンティティクラスキャッシュの実現可能性の調査、パフォーマンスの最適化は常に開発者の焦点でした。どちらか...

極座標における二重積分∫∫YDσ= 0の理由は何ですか?極座標における二重積分∫∫YDσ= 0の理由は何ですか?Apr 19, 2025 pm 05:03 PM

極座標系下での二重積分の解決この記事では、極座標の下での二重積分に関する質問に詳細に答えます。質問はポイントエリアを与え、組み込まれています...

高い並行性の下でアウトバウンドスクリプトタスクの独自性を確保し、リアルタイムで動作ステータスを監視する方法は?高い並行性の下でアウトバウンドスクリプトタスクの独自性を確保し、リアルタイムで動作ステータスを監視する方法は?Apr 19, 2025 pm 05:00 PM

スクリプトタスクの独自性を確保し、高い並行性環境での動作ステータスを監視する方法は?この記事では、クラスター環境でアウトバウンドフットを確保する方法について説明します...

サブクラスは、親クラスのSetNameメソッドを継承することにより、どのように私有地を設定しますか?サブクラスは、親クラスのSetNameメソッドを継承することにより、どのように私有地を設定しますか?Apr 19, 2025 pm 04:57 PM

サブクラスが親クラスのSetNameメソッドを継承することにより、私有地を設定する方法について。プログラミングでは、特にJava、サブクラス、...などのオブジェクト指向プログラミング言語で

Eclipse Pahoを使用してローカルEMQXに接続する際のユーザー名とパスワード認証の失敗の問題を解決する方法は?Eclipse Pahoを使用してローカルEMQXに接続する際のユーザー名とパスワード認証の失敗の問題を解決する方法は?Apr 19, 2025 pm 04:54 PM

eclipsepahoのmqttasyncclientを使用してローカルEMQXに接続する際のユーザー名とパスワード認証の障害の問題を解決する方法は? JavaとEclipseを使用して...

会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は?会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は?Apr 19, 2025 pm 04:51 PM

一部のアプリケーションが適切に機能しないようにする会社のセキュリティソフトウェアのトラブルシューティングとソリューション。多くの企業は、内部ネットワークセキュリティを確保するためにセキュリティソフトウェアを展開します。 ...

JavaのパラメーターQRコードを使用してWeChatアプレットを正しく生成して表示する方法は?JavaのパラメーターQRコードを使用してWeChatアプレットを正しく生成して表示する方法は?Apr 19, 2025 pm 04:48 PM

Javaにパラメーターを使用してWeChatアプレットQRコードを生成し、HTMLページに表示することは一般的な要件です。この記事では、Jの使用方法について詳しく説明します。

See all articles

ホット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ヘンタイを無料で生成します。

ホットツール

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール