成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

開發(fā) 后端 算法

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

基本思想

n個記錄的文件的直接選擇排序可經過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個記錄的文件的直接選擇排序可經過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. 經典四講貫通C++排序之四 選擇排序
責任編輯:于鐵 來源: 百度
相關推薦

2011-04-20 15:06:44

堆排序

2011-04-20 15:20:03

快速排序

2011-04-20 14:19:00

希爾排序

2011-04-20 14:07:37

冒泡排序

2011-04-20 16:05:15

基數(shù)排序

2011-04-20 12:49:44

插入排序

2011-04-20 14:29:07

歸并排序

2019-09-17 16:30:18

java排序算法

2015-08-26 10:13:55

排序算法總結

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

排序算法選擇

2009-08-11 09:19:52

C#選擇排序C#算法

2019-10-30 08:53:46

JavaScript冒泡排序選擇排序

2015-10-20 15:09:55

排序算法

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技術棧公眾號

主站蜘蛛池模板: 一区二区三区四区五区在线视频 | 在线播放一区二区三区 | 欧美精品一二三区 | 99re视频在线 | 国产伊人精品 | www.嫩草 | 色毛片| 欧美亚洲综合久久 | 91网在线观看 | 色在线免费 | 日韩亚洲视频 | 欧美日韩一区二区在线观看 | 国产精品久久久久久久久久久久 | 成人 在线 | 91精品国产91久久久久久吃药 | 欧美亚洲视频在线观看 | 精品欧美色视频网站在线观看 | 久久精品二区 | www.日日操 | 999久久久免费精品国产 | 夫妻午夜影院 | 91久久久久久 | 国产婷婷在线视频 | 午夜黄色影院 | 国产91九色 | av一区在线观看 | 美女黄18岁以下禁止观看 | 亚洲看片网站 | 久久国产婷婷国产香蕉 | 欧美久| 99色综合 | 亚洲国产成人av好男人在线观看 | 在线观看国产三级 | 成人在线视频一区二区三区 | 91欧美精品成人综合在线观看 | 成年人在线观看视频 | 91精品国产日韩91久久久久久 | 综合久久国产 | 日韩 国产 在线 | 欧美精品一二三 | 精品国产乱码久久久久久a丨 |