Java ソートアルゴリズムの概要 (II): 選択ソート

Java ソートアルゴリズムの概要 (II): 選択ソート

選択ソートの基本的な操作は、ソートするデータ要素から毎回最小(または最大)の要素を選択し、ソートするすべてのデータ要素がソートされるまで、ソートされたシーケンスの最後に順番に配置することです。このアルゴリズムは不安定で、追加スペースが O(1)、比較に O(n^2) の時間計算量、スワップに O(n) の時間計算量があり、適応性がありません。ほとんどの場合は推奨されません。これは、スワップの数を減らしたい場合にのみ使用してください。

基本的な考え方

n 個のレコードを持つファイルの直接選択ソートは、n-1 個の直接選択ソートによってソートされ、順序付けられた結果を得ることができます。

①初期状態:順序付けされていない領域はR[1..n]であり、順序付けされた領域は空である。

②1次選別

順序付けられていない領域R[1..n]内で最小のキーワードを持つレコードR[k]を選択し、それを順序付けられていない領域の最初のレコードR[1]と交換します。これにより、R[1..1]とR[2..n]は、それぞれレコードが1つ多い新しい順序付けられた領域と、レコードが1つ少ない新しい順序付けられていない領域になります。

③ i番目のソート

i番目のソートが開始されると、現在の順序付けされた領域と順序付けされていない領域はそれぞれR[1..i-1]とR(1≤i≤n-1)になります。このソートパスは、現在の順序付けられていない領域から最小のキーワードを持つレコード R[k] を選択し、それを順序付けられていない領域の最初のレコード R と交換します。これにより、R[1..i] と R は、それぞれレコードが 1 つ多い新しい順序付けられた領域と、レコードが 1 つ少ない新しい順序付けられていない領域になります。

この方法では、n 個のレコードを持つファイルの直接選択ソートを n-1 回の直接選択ソートでソートして、順序付けられた結果を得ることができます。

コードの実装

  1. 公共 クラステスト{
  2. 公共 静的  int [] a = { 10 , 32 , 1 , 9 , 5 , 7 , 12 , 0 , 4 , 3 }; // プリセットデータ配列 
  3. 公共 静的  void main(文字列args[]) {
  4. int i; // ループカウント変数 
  5. int Index = a.length; // データインデックス変数 
  6. System.out.print( "ソート前: " );
  7. (i = 0 ; i < インデックス - 1 ; i++)の場合
  8. System.out.printf( "%3s" , a);
  9. System.out.println( "" );
  10. SelectSort(Index - 1 ); // 選択ソート 
  11. // ソートされた結果 
  12. System.out.print( "ソート後: " );
  13. (i = 0 ; i < インデックス - 1 ; i++)の場合
  14. System.out.printf( "%3s" , a);
  15. System.out.println( "" );
  16. }
  17. 公共 静的  void SelectSort( intインデックス) {
  18. int i, j, k; // ループカウント変数 
  19. int MinValue; // 最小値変数 
  20. int IndexMin; // 最小インデックス変数 
  21. int Temp; // 一時変数 
  22. ( i = 0 ; i < インデックス - 1 ; i++) {
  23. MinValue = 32767 ; //現在の最小値 
  24. IndexMin = 0 ; // 最小値のインデックス値を保存します 
  25. (j = i; j < Index; j++)の場合{
  26. if (a[j] < MinValue) // 最小値を見つける 
  27. {
  28. MinValue = a[j]; // 最小値を保存する 
  29. インデックス最小値 = j;
  30. }
  31. Temp = a; // 2つの値を交換する 
  32. ア = ア;
  33. a = 温度;
  34. }
  35. System.out.print( "ソート: " );
  36. (k = 0 ; k < インデックス; k++)の場合
  37. System.out.printf( "%3s" , a[k]);
  38. System.out.println( "" );
  39. }
  40. }
  41. }

選択ソート法はバブルソート法と同じです。最も外側のループは依然として n-1 回実行する必要があり、効率は依然として悪いです。

【編集者のおすすめ】

  1. 5.5.5 直接選択ソートの使用
  2. C# アルゴリズムの選択ソートの簡単な分析
  3. C++ ソートの 4 つの選択ソートによる古典的な 4 つの講義

<<:  Java ソートアルゴリズムの概要 (パート 3): バブル ソート

>>:  Javaソートアルゴリズムの概要(I):挿入ソート

ブログ    
ブログ    

推薦する

最も人気のある 15 の機械学習フレームワークのうち、いくつ知っていますか?

機械学習エンジニアは、製品の開発やアルゴリズムの構築を行うチームの重要なメンバーです。データの専門家...

数秒で理解:小売業における画像認識

【51CTO.comオリジナル記事】スーパーマーケットに入ったところを想像してみてください。計量のた...

95 年以降の DAMO アカデミーのインターン生がマイクロソフトに勝ち、最も難しい NLP タスクの世界記録を更新

アリババAIは、常識QA分野の権威あるデータセットであるCommonsenseQAで新たな世界記録を...

Pythonがリードを拡大、PyTorchはわずか6.4%

最近、有名なデータサイエンスのウェブサイト KDnuggets が、2018 年のデータサイエンスお...

メルセデス・ベンツCIO:デジタル変革には人工知能の推進力が必要

メルセデス・ベンツは長年、機械学習と従来の人工知能に依存してきました。しかし、現在では、たとえば M...

...

AIと5Gを組み合わせてIoTの収益を最大化する方法

[[402984]]研究によると、人工知能と 5G テクノロジーを組み合わせることで、通信会社は I...

Googleは、生成AI製品のユーザーを著作権侵害の申し立てから保護することを約束

Googleは10月13日、現地時間公開のブログ投稿で、自社の生成AI製品のユーザーは当局によって保...

英国メディア:中国と米国の人工知能の覇権争いで欧州は敗退

[[223787]]英国メディアは、現在の人工知能ブームの最も注目すべき特徴の一つは、中国が突如とし...

...

...

2023 年の人工知能エンジニアリングの 5 つの新しい方向性

LLMの大幅な増加に加え、AI開発ツールも拡大しています。今年の AI 開発における 5 つの主要な...

AIがデータセンターを管理するのに時間がかかる理由

ハイパースケーラーはすでに業務改善のために AI を活用していますが、他のほとんどのデータセンターで...

人工知能技術は交通にどのように応用できるのでしょうか?

都市交通の分野では、AI信号制御、インテリジェントな街路交通監視、スマートバス停、スマート高速道路な...

Yisaqi 9周年: RPA製品の進化を振り返る

現在、国内RPA市場の競争は激化しており、多くのメーカーが独自のRPA製品やブランドを立ち上げていま...