検索
ホームページJava&#&チュートリアルJava でのクイックソートの簡単な例

Java でのクイックソートの簡単な例

Aug 11, 2017 am 09:36 AM
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. ソートアルゴリズムの実装


rree

以上がJava でのクイックソートの簡単な例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Javaがクロスプラットフォームデスクトップアプリケーションを開発するための人気のある選択肢なのはなぜですか?Javaがクロスプラットフォームデスクトップアプリケーションを開発するための人気のある選択肢なのはなぜですか?Apr 25, 2025 am 12:23 AM

javaispopularforsoss-platformdesktopapplicationsduetoits "writeonce、runaynay" philosophy.1)itusesbytecodatiTatrunnanyjvm-adipplatform.2)ライブラリリケンディンガンドジャヴァフククレアティック - ルルクリス

Javaでプラットフォーム固有のコードを作成する必要がある場合がある状況について話し合います。Javaでプラットフォーム固有のコードを作成する必要がある場合がある状況について話し合います。Apr 25, 2025 am 12:22 AM

Javaでプラットフォーム固有のコードを作成する理由には、特定のオペレーティングシステム機能へのアクセス、特定のハードウェアとの対話、パフォーマンスの最適化が含まれます。 1)JNAまたはJNIを使​​用して、Windowsレジストリにアクセスします。 2)JNIを介してLinux固有のハードウェアドライバーと対話します。 3)金属を使用して、JNIを介してMacOSのゲームパフォーマンスを最適化します。それにもかかわらず、プラットフォーム固有のコードを書くことは、コードの移植性に影響を与え、複雑さを高め、パフォーマンスのオーバーヘッドとセキュリティのリスクをもたらす可能性があります。

プラットフォームの独立性に関連するJava開発の将来の傾向は何ですか?プラットフォームの独立性に関連するJava開発の将来の傾向は何ですか?Apr 25, 2025 am 12:12 AM

Javaは、クラウドネイティブアプリケーション、マルチプラットフォームの展開、および言語間の相互運用性を通じて、プラットフォームの独立性をさらに強化します。 1)クラウドネイティブアプリケーションは、GraalvmとQuarkusを使用してスタートアップ速度を向上させます。 2)Javaは、埋め込みデバイス、モバイルデバイス、量子コンピューターに拡張されます。 3)Graalvmを通じて、JavaはPythonやJavaScriptなどの言語とシームレスに統合して、言語間の相互運用性を高めます。

Javaの強力なタイピングは、プラットフォームの独立性にどのように貢献しますか?Javaの強力なタイピングは、プラットフォームの独立性にどのように貢献しますか?Apr 25, 2025 am 12:11 AM

Javaの強力なタイプ化されたシステムは、タイプの安全性、統一タイプの変換、多型を通じてプラットフォームの独立性を保証します。 1)タイプの安全性は、コンパイル時間でタイプチェックを実行して、ランタイムエラーを回避します。 2)統一された型変換ルールは、すべてのプラットフォームで一貫しています。 3)多型とインターフェイスメカニズムにより、コードはさまざまなプラットフォームで一貫して動作します。

Javaネイティブインターフェイス(JNI)がプラットフォームの独立性をどのように妥協できるかを説明します。Javaネイティブインターフェイス(JNI)がプラットフォームの独立性をどのように妥協できるかを説明します。Apr 25, 2025 am 12:07 AM

JNIはJavaのプラットフォームの独立を破壊します。 1)JNIは特定のプラットフォームにローカルライブラリを必要とします。2)ローカルコードをターゲットプラットフォームにコンパイルおよびリンクする必要があります。3)異なるバージョンのオペレーティングシステムまたはJVMは、異なるローカルライブラリバージョンを必要とする場合があります。

Javaのプラットフォームの独立性を脅かしたり強化したりする新しいテクノロジーはありますか?Javaのプラットフォームの独立性を脅かしたり強化したりする新しいテクノロジーはありますか?Apr 24, 2025 am 12:11 AM

新しいテクノロジーは、両方の脅威をもたらし、Javaのプラットフォームの独立性を高めます。 1)Dockerなどのクラウドコンピューティングとコンテナ化テクノロジーは、Javaのプラットフォームの独立性を強化しますが、さまざまなクラウド環境に適応するために最適化する必要があります。 2)WebAssemblyは、Graalvmを介してJavaコードをコンパイルし、プラットフォームの独立性を拡張しますが、パフォーマンスのために他の言語と競合する必要があります。

JVMのさまざまな実装は何ですか、そしてそれらはすべて同じレベルのプラットフォームの独立性を提供しますか?JVMのさまざまな実装は何ですか、そしてそれらはすべて同じレベルのプラットフォームの独立性を提供しますか?Apr 24, 2025 am 12:10 AM

JVMの実装が異なると、プラットフォームの独立性が得られますが、パフォーマンスはわずかに異なります。 1。OracleHotspotとOpenJDKJVMは、プラットフォームの独立性で同様に機能しますが、OpenJDKは追加の構成が必要になる場合があります。 2。IBMJ9JVMは、特定のオペレーティングシステムで最適化を実行します。 3. Graalvmは複数の言語をサポートし、追加の構成が必要です。 4。AzulzingJVMには、特定のプラットフォーム調整が必要です。

プラットフォームの独立性は、開発コストと時間をどのように削減しますか?プラットフォームの独立性は、開発コストと時間をどのように削減しますか?Apr 24, 2025 am 12:08 AM

プラットフォームの独立性により、開発コストが削減され、複数のオペレーティングシステムで同じコードセットを実行することで開発時間を短縮します。具体的には、次のように表示されます。1。開発時間を短縮すると、1セットのコードのみが必要です。 2。メンテナンスコストを削減し、テストプロセスを統合します。 3.展開プロセスを簡素化するための迅速な反復とチームコラボレーション。

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衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 英語版

SublimeText3 英語版

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

EditPlus 中国語クラック版

EditPlus 中国語クラック版

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

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター