C# クイックソート
C# クイック ソート
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Sort { class QuickSorter { private static int[] myArray; private static int arraySize; public static int[] Sort(int[] a) { arraySize = a.Length; QuickSort(a, 0,arraySize- 1); return a; } private static void QuickSort(int[] myArray, int left, int right) { int i, j, s; if (left < right) { i = left - 1; j = right + 1; s = myArray[(i + j) / 2]; while (true) { while (myArray[++i] < s) ; while (myArray[--j] > s) ; if (i >= j) break; Swap(ref myArray[i], ref myArray[j]); } QuickSort(myArray, left, i - 1); QuickSort(myArray, j + 1, right); } } private static void Swap(ref int left, ref int right) { int temp; temp = left; left = right; right = temp; } } }
クイック ソートのアイデア:
ソートする配列が A[0]...A[N-1] であると仮定し、最初に任意のデータ (通常は配列の最初の番号) を選択します。 ) をキー データとして、その前にそれより小さいすべての数字を置き、その前にそれより大きいすべての数字を置くこのプロセスは、ワンパス クイック ソートと呼ばれます。クイックソートは安定したソートアルゴリズムではないことに注意してください。つまり、複数の同一の値の相対位置がアルゴリズムの終了時に変わる可能性があります。
ワンパスクイックソートのアルゴリズムは次のとおりです:
1) ソート開始時に 2 つの変数 i と j を設定します: i=0、j=N-1; 2) 最初の配列要素をキーデータとして使用します。 、キーに値を代入します、つまり key=A[0]
3) j から前方検索、つまり後方 (j--) から前方検索し、最初の値 A[j] を見つけます。 key より小さい値の項目を A[j] と交換します
4) i から逆方向に検索、つまり前から逆方向に検索 (i++)、大きい最初の A[i] を見つけます。キー項目を A[i] と交換します
5) ステップ 3 を繰り返します
6) i=j になるまでステップ 3、4、および 5 を繰り返します。条件を満たす値が見つからなかった場合、つまり、3のA[j]がkey以上、4のA[j]がkey以下の場合、jとiの値を次のように変更します。 j=j-1、i=i+1、条件を満たす値が見つかるまで、i==j の処理は常に行われなければなりません。 i+ または j- が完了し、その時点でループが終了します)。
例:
配列を例として、区間内の最初の数値を基数とします。
i = 3; j = 7;
j=5 のとき、条件が満たされていれば a[5] を掘り出して前の穴に埋めます、 a[3] = a[5];
から逆方向に開始します。 i 検索、i=5 の場合、i==j なので終了します。
このとき、i = j = 5で、a[5]がたまたま前回掘った穴なので、a[5]にXを入れます。
配列は次のようになります:
上記は C# クイック ソートの内容です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) に注目してください。
ホット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)

ホットトピック











C# を使用した Active Directory のガイド。ここでは、Active Directory の概要と、C# での動作方法について、構文と例とともに説明します。

C# データ グリッド ビューのガイド。ここでは、SQL データベースまたは Excel ファイルからデータ グリッド ビューをロードおよびエクスポートする方法の例について説明します。

マルチスレッドと非同期の違いは、マルチスレッドが複数のスレッドを同時に実行し、現在のスレッドをブロックせずに非同期に操作を実行することです。マルチスレッドは計算集約型タスクに使用されますが、非同期はユーザーインタラクションに使用されます。マルチスレッドの利点は、コンピューティングのパフォーマンスを改善することですが、非同期の利点はUIスレッドをブロックしないことです。マルチスレッドまたは非同期を選択することは、タスクの性質に依存します。計算集約型タスクマルチスレッド、外部リソースと相互作用し、UIの応答性を非同期に使用する必要があるタスクを使用します。
