C# ヒルソート
C# ヒル ソート
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Sort { class ShellSorter { public static int[] Sort(int[] a) { ShellSort(a); return a; } public static void ShellSort(int[] myArray) { int i, j, increment; int temp; for (increment = myArray.Length / 2; increment > 0; increment /= 2) { for (i = increment; i < myArray.Length; i++) { temp = myArray[i]; for (j = i; j >= increment; j -= increment) { if (temp < myArray[j - increment]) myArray[j] = myArray[j - increment]; else break; } myArray[j] = temp; } } } } }
ヒル ソートは、直接挿入ソート アルゴリズムを改良したもので、最初にソートされたシーケンス全体をいくつかのサブシーケンスに分割し、基本的にシーケンス全体の後でサブシーケンスに対して直接挿入ソートを実行することです。すべてに対して直接挿入ソートを実行します。これは、新しい順序付けされたシーケンスを形成するために使用されます。一般的な除算方法は、2 つの要素間の距離が d=n/2、n/4、n/8... などとなることです。
1. 基本的な考え方:
並べ替えるデータ要素全体をいくつかのグループに分割し、直接挿入方法を使用して同じグループ内のデータ要素を並べ替え、グループの数を徐々に減らし、完了するとすべてのデータ要素を並べ替えます。 1 つのグループ内 ソート後にソート処理は終了します。
2. スキル:
グループの構成は単純に「セグメントごとに分ける」のではなく、一定の増分 dk で区切られたレコードをグループ化し、増分 dk を段階的に短くしていきます (例: 5、 3、1 が順に取得され、dk=1 になるまで続きます。
3. 利点:
キーワード値が小さい要素を素早く進めることができ、順序が基本的に整っていれば、直接挿入ソートを使用できるため、時間効率が大幅に向上します。
例 1:
例 2:
フローチャート

ホット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の応答性を非同期に使用する必要があるタスクを使用します。
