クイックソートの実装方法
クイックソート方法
HTML5 Academy-Coder: 「アルゴリズムの旅」の前号で、バブルソート方法と選択ソート方法を共有しました。どちらも時間計算量が O(n^) で「遅い」です。 2) 並べ替えます。今日は、さまざまなソート アルゴリズムの中で最も広く使用され、高速なソート アルゴリズムであるクイック ソート [平均時間計算量は O (n logn)] を紹介したいと思います。
ヒント1:「アルゴリズム」と「並べ替え」の基礎知識は、前回の「選択範囲の並べ替え方法」で詳しく説明していますので、記事末尾の該当記事リンクをクリックしてご覧ください。ここでは繰り返しません。
ヒント 2: 特に指定がない限り、この記事のクイック ソートは小さいものから大きいものの順に並べられています。
クイックソートの原理
クイックソートは分割交換ソートであり、通常分割統治法と呼ばれます。
分割統治法
基本的な考え方: 元の問題を、元の問題とサイズは小さいが構造が似ているいくつかのサブ問題に分解します。これらの部分問題を再帰的に解決し、これらの部分問題の結果を元の問題の結果に結合します。
基本原則
「基数」としてシーケンスから任意の数値を選択します。
「基数」より小さいすべての数値は「基数」以上のすべての数値に移動します。は「ベースライン」の右側の「」に移動されます。
この移動が終了すると、「ベースライン」は 2 つのシーケンスの中央になり、その後の並べ替えには参加しなくなります。
について繰り返します。 「ベースライン」の左右に 2 つのサブシーケンス すべてのサブシーケンスに 1 つの数値だけが残るまで、上記の手順が繰り返されます。
原理の図
既存のシーケンス [8、4、7、2、0、3、1] があり、以下はクイック ソート方法を使用して並べ替える方法を示します。
クイックソートを実装する手順の内訳
「ベンチマーク」を選択し、元の配列から分離します
まずベンチマークのインデックス値を取得し、次にスプライス配列メソッドを使用してベンチマーク値を取り出します。
ヒント: この例では、ベンチマークのインデックス値 = parseInt (シーケンス長 / 2)
ヒント: splice メソッドは元の配列を変更します。たとえば、 arr = [1, 2, 3]; ベースのインデックス値が 1、ベースの値が 2 の場合、元の配列は arr = [1, 3] になります
シーケンスを走査し、シーケンスを分割します
; 「ベースライン」サイズで 2 つのサブシーケンスに分割します
「ベースライン」より小さい数値は leftArr 配列に保存され、「ベースライン」以上の数値は rightArr 配列に保存されます
ヒント: もちろん、以下を入れることもできます。数値「ベンチマーク」は leftArr に格納され、「ベンチマーク」より大きい数値は rightArr に格納されます
シーケンスを走査してサイズを比較する必要があるため、各数値を「ベンチマーク」にするには、for ステートメントを使用して再帰呼び出しを実装し、サブシーケンスを走査し、サブシーケンスの結果を結合する必要があります
関数を定義し、仮パラメーターは配列を受け取るために使用されます
- サブシーケンスを走査するための再帰呼び出しを実装し、concat配列メソッドを使用しますサブシーケンスを結合した結果
サブシーケンスの長さを判断します
再帰呼び出しでは、サブシーケンスの長さが 1 に等しい場合、再帰呼び出しは停止し、現在の配列が返されます。
クイックソートメソッドの完全なコード
クイックソートメソッドの効率
時間の複雑さ
アルゴリズムの安定性
クイックソートは不安定なソートアルゴリズムです
例: 既存のシーケンスは[1, 0, 1, 3]で、「ベースライン」の数値が2番目の1として選択されます
最初のラウンドでは比較後は[0, 1, 1, 3]となり、左の列が[0]、右の列が[1, 3]になります(右の列の1は前の1です)
です見つけるのは難しくありません。元のシーケンスにある 2 つの 1 の順序が破壊され、順序が変更されます。これは当然、「不安定な」ソート アルゴリズムです
O について
前回の記事「バブルソート方法」では、 Oとは何か、ここでは多くは言いませんが、写真を見てください
以上がクイックソートの実装方法の詳細内容です。詳細については、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)

ホットトピック











残念ながら、WeChat は広く使用されているソーシャル ソフトウェアであり、何らかの理由で特定の連絡先を誤って削除してしまうことがよくあります。ユーザーがこの問題を解決できるように、この記事では、削除された連絡先を簡単な方法で取得する方法を紹介します。 1. WeChat の連絡先削除メカニズムを理解します。これにより、削除された連絡先を取得できるようになります。WeChat の連絡先削除メカニズムでは、連絡先がアドレス帳から削除されますが、完全には削除されません。 2. WeChat の組み込みの「連絡先帳復元」機能を使用します。WeChat には、この機能を通じて以前に削除した連絡先をすばやく復元できる「連絡先帳復元」機能が用意されています。 3. WeChat 設定ページに入り、右下隅をクリックし、WeChat アプリケーション「Me」を開き、右上隅にある設定アイコンをクリックして設定ページに入ります。

トマト ノベルは非常に人気のある小説閲覧ソフトウェアです。トマト ノベルでは、新しい小説や漫画を読むことができます。どの小説も漫画もとても面白いです。小説を書きたい友達もたくさんいます。お小遣いを稼いで、小説の内容を編集することもできます。 「テキストに文章を書きたいです。それで、小説はどうやって書くのですか?友達は知らないので、一緒にこのサイトに行きましょう。小説の書き方の入門を少し見てみましょう。」 Tomato Novels を使用して小説を書く方法に関するチュートリアルを共有します。 1. まず、携帯電話で Tomato Free Novels アプリを開き、パーソナル センター - ライター センターをクリックします。 2. Tomato Writer Assistant ページに移動し、次の場所で [新しい本の作成] をクリックします。小説の終わり

Colorful マザーボードは中国国内市場で高い人気と市場シェアを誇っていますが、Colorful マザーボードのユーザーの中には、設定のために BIOS を入力する方法がまだ分からない人もいます。この状況に対応して、編集者はカラフルなマザーボード BIOS に入る 2 つの方法を特別に提供しました。ぜひ試してみてください。方法 1: U ディスク起動ショートカット キーを使用して、U ディスク インストール システムに直接入ります。ワンクリックで U ディスクを起動する Colorful マザーボードのショートカット キーは ESC または F11 です。まず、Black Shark インストール マスターを使用して、Black Shark インストール マスターを作成します。 Shark U ディスク起動ディスクを選択し、コンピュータの電源を入れます。起動画面が表示されたら、キーボードの ESC キーまたは F11 キーを押し続けて、起動項目を順次選択するウィンドウに入ります。「USB」の場所にカーソルを移動します。 」と表示され、その後

テクノロジーの発展に伴い、モバイルゲームは人々の生活に欠かせないものになりました。かわいいドラゴンエッグの画像と面白い孵化過程で多くのプレイヤーの注目を集めており、その中でも注目を集めているゲームの一つがモバイル版ドラゴンエッグです。プレイヤーがゲーム内で自分のドラゴンをより適切に育成し成長させることができるように、この記事ではモバイル版でドラゴンの卵を孵化させる方法を紹介します。 1. 適切な種類のドラゴン エッグを選択する プレイヤーは、ゲーム内で提供されるさまざまな種類のドラゴン エッグの属性と能力に基づいて、自分に適したドラゴン エッグの種類を慎重に選択する必要があります。 2. 孵化機のレベルをアップグレードします。プレイヤーはタスクを完了し、小道具を収集することで孵化機のレベルを向上させる必要があります。孵化機のレベルは孵化速度と孵化成功率を決定します。 3. プレイヤーはゲームに参加する必要がある孵化に必要なリソースを収集します。

携帯電話が人々の日常生活において重要なツールになるにつれて、フォント サイズの設定は重要なパーソナライゼーション要件になりました。さまざまなユーザーのニーズを満たすために、この記事では、簡単な操作で携帯電話の使用体験を向上させ、携帯電話のフォントサイズを調整する方法を紹介します。携帯電話のフォント サイズを調整する必要があるのはなぜですか - フォント サイズを調整すると、テキストがより鮮明で読みやすくなります - さまざまな年齢のユーザーの読書ニーズに適しています - フォント サイズを使用すると、視力の悪いユーザーにとって便利です携帯電話システムの設定機能 - システム設定インターフェイスに入る方法 - 設定インターフェイスで「表示」オプションを見つけて入力します。 - 「フォント サイズ」オプションを見つけて、サードパーティでフォント サイズを調整します。アプリケーション - フォント サイズの調整をサポートするアプリケーションをダウンロードしてインストールします - アプリケーションを開いて、関連する設定インターフェイスに入ります - 個人に応じて

今日の社会において、携帯電話は私たちの生活に欠かせないものとなっています。私たちの日常のコミュニケーション、仕事、生活のための重要なツールとして、WeChat はよく使用されます。ただし、異なるトランザクションを処理する場合は 2 つの WeChat アカウントを分離する必要がある場合があり、そのためには携帯電話が 2 つの WeChat アカウントへの同時ログインをサポートする必要があります。有名な国内ブランドとして、ファーウェイの携帯電話は多くの人に使用されていますが、ファーウェイの携帯電話で 2 つの WeChat アカウントを開設する方法は何でしょうか?このメソッドの秘密を明らかにしましょう。まず、Huawei 携帯電話で 2 つの WeChat アカウントを同時に使用する必要があります。最も簡単な方法は次のとおりです。

Go 言語のメソッドと関数の違いは、構造との関連付けにあります。メソッドは構造に関連付けられ、構造データまたはメソッドを操作するために使用されます。関数は型に依存せず、一般的な操作を実行するために使用されます。

Win11 の「マイ コンピュータ」パスの違いは何ですか?すぐに見つけられる方法! Windows システムは常に更新されているため、最新の Windows 11 システムにもいくつかの新しい変更と機能が追加されています。よくある問題の 1 つは、Win11 システムでユーザーが「マイ コンピューター」へのパスを見つけられないことですが、これは通常、以前の Windows システムでは簡単な操作でした。この記事では、Win11 システムでの「マイ コンピュータ」のパスの違いと、それらをすばやく見つける方法を紹介します。 Windows1の場合
