#コンセプト
クイック並べ替えは交換並べ替えです。主な手順は、比較に参照要素を使用することです。基準要素より小さい要素を並べ替えると、ベース要素より大きい要素は一方の側に移動し、ベース要素より大きい要素は反対側に移動します。したがって、配列は 2 つの部分に分割され、次にその 2 つの部分から参照要素が選択され、上記のステップが繰り返されます。プロセスは次のとおりです。 (推奨ビデオ:java ビデオ チュートリアル )
紫: 基本要素緑色: 基本要素 ## より大きい# 黄色: ベースライン要素未満
#この考え方は分割統治と呼ばれます。
データム要素の選択はランダムに選択できます。次の使用では、最初の要素を基本要素として使用します。
並べ替えプロセス並べ替えと分割のプロセスは次のとおりです。
紫は基本要素です ( で再選択されています)。各ラウンド)緑はその他の要素第一ラウンド
第二ラウンド
第三ラウンド
上図に示すように:
要素数が n の場合、ソート処理はすべての要素を比較する必要があるため、時間計算量は O( n),
平均して、ソート ラウンドには logn ラウンドが必要であるため、クイック ソートの平均時間計算量は O(nlogn) です。
#分別の実施方法
実施方法には両側循環方式と片側循環方式があります
双方向循環方式
最初の選択肢は、ピボット要素 (ピボット) 4 を選択し、次のように配列の左端と右端の要素を指すようにポインターを左右に設定することです。
First このループでは、まず右ポインタ (rightData) が指すデータから開始し、基本要素と比較します。rightData >= pivot の場合、右ポインタは左に移動します。 . rightData
最初のポインタの移動の後、次の構造が得られます。次に、left と right が指す要素が交換されます。
実装コード
public class DoubleSort { public static void quickSort(int[] arr, int startIndex, int endIndex) { //递归结束条件 if (startIndex >= endIndex) { return; } // 基准元素位置 int pivotIndex = partition(arr, startIndex, endIndex); // 根据基准元素,分成两部分进行递归排序 quickSort(arr, startIndex, pivotIndex - 1); quickSort(arr, pivotIndex + 1, endIndex); } public static int partition(int[] arr, int startIndex, int endIndex) { // 取第一个元素为基准元素,也可以随机抽取 int pivot = arr[startIndex]; int left = startIndex; int right = endIndex; while (left != right) { // 控制right指针比较并左移 while (left = pivot) { right--; } // 控制left指针比较并右移 while (left <p></p>片ループ方式<p id="实现代码" style="white-space: normal;"><strong></strong>双方向ループ方式は、配列の両側の要素を比較して交換します。片側ループ ルールは配列の片側から走査し、逆方向に比較および交換するため、実装が容易になります。 </p>プロセスは次のとおりです。 <p id="单边循环法" style="white-space: normal;"><strong></strong>最初に、ピボット要素が選択されます (ランダムに選択できます) </p>マーク ポインタを、配列の開始位置を指すように設定します。ベースライン要素よりも小さい領域境界 (理解できません。後で要素を交換するために使用されると理解してください) <p><br></p>元の配列は次のとおりです: <blockquote> <p><br> </p> <blockquote><p>从基准元素下一位开始遍历数组<br>如果该元素大于基准元素,继续往下遍历<br>如果该元素小于基准元素,mark指针往右移,因为小于基准元素的区域边界增大了1(即小于基准元素的多了1位),所以mark就 +1,并且该元素和mark指向元素进行交换。</p></blockquote> <p>遍历到元素3时,因为3 </p> <p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/040/baca0480a2a4ba4850e39cd5916f2819-12.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Javaソートアルゴリズムを素早くマスター - クイックソート(画像とテキスト)"></p> <p>然后交换元素</p> <p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/040/baca0480a2a4ba4850e39cd5916f2819-13.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Javaソートアルゴリズムを素早くマスター - クイックソート(画像とテキスト)"></p> <p>然后就继续遍历,根据上面的步骤进行判断,后面的过程就不写了。</p> <p id="实现代码-1" style="white-space: normal;"><strong>实现代码</strong></p> <pre class="brush:php;toolbar:false">public class SingleSort { public static void quickSort(int[] arr, int startIndex, int endIndex) { //递归结束条件 if (startIndex >= endIndex) { return; } // 基准元素位置 int pivotIndex = partition(arr, startIndex, endIndex); // 根据基准元素,分成两部分进行递归排序 quickSort(arr, startIndex, pivotIndex - 1); quickSort(arr, pivotIndex + 1, endIndex); } /** * 分治(单边循环法) * @param arr * @param startIndex * @param endIndex * @return */ public static int partition(int[] arr, int startIndex, int endIndex) { // 取第一个元素为基准元素,也可以随机抽取 int pivot = arr[startIndex]; int mark = startIndex; for(int i = startIndex + 1; i<p id="总结" style="white-space: normal;"><strong>总结</strong></p><p>本人也是初次接触算法,慢慢的去理解算法的思路和实现过程后,真是为自己以往写的算法感到羞愧。该文章也是为了加深自己对快排算法的印象,若文章有不足之处,恳请各位在下方留言补充。感谢各位的阅读。Thanks♪(・ω・)ノ。</p><p>参考资料:《小灰的算法之旅》 第四章。</p><p>本文来自php中文网,<a href="https://www.php.cn/java/base/" target="_blank">java教程</a>栏目,欢迎学习! </p>
以上がJavaソートアルゴリズムを素早くマスター - クイックソート(画像とテキスト)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

WebStorm Mac版
便利なJavaScript開発ツール

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

Dreamweaver Mac版
ビジュアル Web 開発ツール

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター
