偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

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

開發(fā) 后端 算法

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

基本思想

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

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

②第1趟排序   

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

……

 ③第i趟排序   

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

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

代碼實(shí)現(xiàn)

  1. public class Test {   
  2. public static int[] a = { 1032195712043 }; // 預(yù)設(shè)數(shù)據(jù)數(shù)組   
  3. public static void main(String args[]) {   
  4. int i; // 循環(huán)計(jì)數(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. // 排序后結(jié)果   
  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)計(jì)數(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++排序之四 選擇排序
責(zé)任編輯:于鐵 來源: 百度
相關(guān)推薦

2011-04-20 14:07:37

冒泡排序

2011-04-20 14:19:00

希爾排序

2011-04-20 15:20:03

快速排序

2011-04-20 15:06:44

堆排序

2011-04-20 12:49:44

插入排序

2011-04-20 14:29:07

歸并排序

2011-04-20 16:05:15

基數(shù)排序

2019-09-17 16:30:18

java排序算法

2015-08-26 10:13:55

排序算法總結(jié)

2023-03-06 08:10:52

數(shù)據(jù)結(jié)構(gòu)算法數(shù)據(jù)

2023-09-26 22:22:30

選擇排序Python

2015-09-01 10:21:53

排序算法總結(jié)

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ù)結(jié)構(gòu)堆排序
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號