Java でのクイックソートの簡単な例
この記事では主に Java の簡単なクイックソートの例を詳しく紹介しますので、興味のある方は参考にしてください
1. 基本概念
要素の検索 (理論上は気軽に行うことができます)をピボット (ピボット) として指定し、ピボットの左側の要素の値がピボットの値を超えず、ピボットの右側の要素の値が以下になるように配列を分割します。このようにして、ピボットとしての要素はソート後に正しい値に調整されます。再帰的クイックソートは、ソート後に他の n-1 個の要素を正しい位置に調整します。最後に、ソート後に各要素が正しい位置に配置され、ソートが完了します。したがって、クイック ソート アルゴリズムの中核となるアルゴリズムは分割操作、つまり分割統治再帰のためにベンチマークの位置を調整し、返されたベンチマークの最終位置を調整する方法です。
2. ベンチマーク要素を選択します
1. ベンチマーク要素を修正します
入力シーケンスがランダムであれば、処理時間は許容範囲内です。配列がすでにソートされている場合、この時点での除算は非常に悪い除算です。各除算ではソート対象のシーケンスを 1 つずつ減らすことしかできないため、これは最悪のシナリオであり、クイック ソートはバブル ソートになり、時間計算量は Θ(n^2) になります。さらに、入力データが順序付けされているか、部分的に順序付けされていることが非常に一般的です。したがって、最初の要素を基本要素として使用することは非常に悪いため、すぐに中止する必要があります。
2. ランダムな基本元
これは比較的安全な戦略です。参照要素の位置はランダムであるため、結果として得られるセグメンテーションが常に低品質になるとは限りません。配列全体の番号がすべて等しい場合でも、これは最悪のケースであり、時間計算量は O(n^2) です。実際、理論上の最悪のケースを得るためにクイックソートをランダム化する確率は、わずか 1/(2^n) です。したがって、ランダム化されたクイック ソートは、ほとんどの入力データに対して予想される時間計算量 O(n×log(n)) を達成できます。
3. 3 つの数値の中央を見つける
最良の分割は、並べ替えるシーケンスを同じ長さのサブシーケンスに分割することです。最良の状態では、シーケンスの中央の値 (N/2 番目) を使用できます。番号。ただし、これは計算が難しく、クイックソートの速度が大幅に低下します。このような中央値の推定値は、3 つの要素をランダムに選択し、それらの中央値を基本要素として使用することによって取得できます。実際には、ランダム性はあまり役に立たないため、左端、右端、中央位置の 3 つの要素の中央値をベース要素として使用するのが一般的なアプローチです。
3. パーティションアルゴリズム
パーティションアルゴリズムはクイックソートを学ぶ前に、まずこのアルゴリズムを学ぶことができます。コードは以下に掲載されています:
public int partition(int[] num,int left,int right){ if(num==null || num.length<=0 || left<0 || right>=num.length){ return 0; } int prio=num[left+(right-left)/2]; //获取数组中间元素的下标 while (left<=right){ //从两端交替向中间扫描 while (num[left]<prio) left++; while (num[right]>prio) right--; if (left<=right){ swap(num,left,right); //最终将基准数归位 left++; right--; } } return left; }
このメソッドのアイデアは、まずピボット要素を見つけることです (最初の要素はこのメソッドの実装で見つかります。実際にはそれに関する記事がたくさんありますが、ここでは説明を簡略化します)、配列から開始します (特に、どこに行くかは渡されたパラメーターによって決まります)。左側の要素が大きいことが判明するたびに、左右に 2 つのポインターが生成されます。ピボット要素、i は停止し、右側の要素がピボット要素 j より小さければ停止し、これを 2 つの数字の位置を交換します。左右の2つのポインタが交わるまで。次に、ピボット要素を左側の位置 (本来あるべき場所) に挿入します。
これを実行すると、配列の [left, right] 部分が 2 つの部分に分かれて表示され、左側のピボット要素の最終位置はピボット要素以下になります。右側の値はピボット要素以上です。ピボット要素は完全に正しい位置に挿入されます。
4. ソートアルゴリズムの実装
以上がJava でのクイックソートの簡単な例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

Java での日付までのタイムスタンプに関するガイド。ここでは、Java でタイムスタンプを日付に変換する方法とその概要について、例とともに説明します。

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。
