自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Java排序算法總結(二):選擇排序

開發(fā) 后端 算法

選擇排序的基本操作就是每一趟從待排序的數(shù)據(jù)元素中選出最?。ɑ蜃畲螅┑囊粋€元素,順序放在已排好序的數(shù)列的最后,直到全部待排序的數(shù)據(jù)元素排完。算法不穩(wěn)定,O(1)的額外的空間,比較的時間復雜度為O(n^2),交換的時間復雜度為O(n),并不是自適應的。在大多數(shù)情況下都不推薦使用。只有在希望減少交換次數(shù)的情況下可以用。

基本思想

n個記錄的文件的直接選擇排序可經(jīng)過n-1趟直接選擇排序得到有序結果:   

①初始狀態(tài):無序區(qū)為R[1..n],有序區(qū)為空。   

②第1趟排序   

在無序區(qū)R[1..n]中選出關鍵字最小的記錄R[k],將它與無序區(qū)的第1個記錄R[1]交換,使R[1..1]和R[2..n]分別變?yōu)橛涗泜€數(shù)增加1個的新有序區(qū)和記錄個數(shù)減少1個的新無序區(qū)。   

……

 ③第i趟排序   

第i趟排序開始時,當前有序區(qū)和無序區(qū)分別為R[1..i-1]和R(1≤i≤n-1)。該趟排序從當前無序區(qū)中選出關鍵字最小的記錄 R[k],將它與無序區(qū)的第1個記錄R交換,使R[1..i]和R分別變?yōu)橛涗泜€數(shù)增加1個的新有序區(qū)和記錄個數(shù)減少1個的新無序區(qū)。   

這樣,n個記錄的文件的直接選擇排序可經(jīng)過n-1趟直接選擇排序得到有序結果。   

代碼實現(xiàn)

  1. public class Test {   
  2. public static int[] a = { 1032195712043 }; // 預設數(shù)據(jù)數(shù)組   
  3. public static void main(String args[]) {   
  4. int i; // 循環(huán)計數(shù)變量   
  5. int Index = a.length;// 數(shù)據(jù)索引變量   
  6. System.out.print("排序前: ");   
  7. for (i = 0; i < Index - 1; i++)   
  8. System.out.printf("%3s", a);   
  9. System.out.println("");   
  10. SelectSort(Index - 1); // 選擇排序   
  11. // 排序后結果   
  12. System.out.print("排序后: ");   
  13. for (i = 0; i < Index - 1; i++)   
  14. System.out.printf("%3s", a);   
  15. System.out.println("");   
  16. }   
  17. public static void SelectSort(int Index) {   
  18. int i, j, k; // 循環(huán)計數(shù)變量   
  19. int MinValue; // 最小值變量   
  20. int IndexMin; // 最小值索引變量   
  21. int Temp; // 暫存變量   
  22. for (i = 0; i < Index - 1; i++) {   
  23. MinValue = 32767// 目前最小數(shù)值   
  24. IndexMin = 0// 儲存最小數(shù)值的索引值   
  25. for (j = i; j < Index; j++) {   
  26. if (a[j] < MinValue) // 找到最小值   
  27. {   
  28. MinValue = a[j]; // 儲存最小值   
  29. IndexMin = j;   
  30. }   
  31. Temp = a; // 交換兩數(shù)值   
  32. a = a;   
  33. a = Temp;   
  34. }   
  35. System.out.print("排序中: ");   
  36. for (k = 0; k < Index; k++)   
  37. System.out.printf("%3s", a[k]);   
  38. System.out.println("");   
  39. }   
  40. }   

選擇排序法與冒泡排序法一樣,最外層循環(huán)仍然要執(zhí)行n-1次,其效率仍然較差。

【編輯推薦】

  1. 5.5.5 使用直接選擇排序法
  2. C#算法之選擇排序淺析
  3. 經(jīng)典四講貫通C++排序之四 選擇排序
責任編輯:于鐵 來源: 百度
相關推薦

2011-04-20 14:07:37

冒泡排序

2011-04-20 14:19:00

希爾排序

2011-04-20 15:06:44

堆排序

2011-04-20 15:20:03

快速排序

2011-04-20 14:29:07

歸并排序

2011-04-20 12:49:44

插入排序

2011-04-20 16:05:15

基數(shù)排序

2015-08-26 10:13:55

排序算法總結

2019-09-17 16:30:18

java排序算法

2023-03-06 08:10:52

數(shù)據(jù)結構算法數(shù)據(jù)

2023-09-26 22:22:30

選擇排序Python

2015-09-01 10:21:53

排序算法總結

2021-01-21 05:22:36

排序算法選擇

2015-10-20 15:09:55

排序算法

2009-08-11 09:19:52

C#選擇排序C#算法

2019-10-30 08:53:46

JavaScript冒泡排序選擇排序

2021-01-26 05:33:07

排序算法快速

2023-10-05 09:01:05

插入排序對象序列log2i

2022-01-06 16:20:04

Java排序算法排序

2021-01-19 07:02:26

算法數(shù)據(jù)結構堆排序
點贊
收藏

51CTO技術棧公眾號