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

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):無(wú)序區(qū)為R[1..n],有序區(qū)為空。   

②第1趟排序   

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

……

 ③第i趟排序   

第i趟排序開始時(shí),當(dāng)前有序區(qū)和無(wú)序區(qū)分別為R[1..i-1]和R(1≤i≤n-1)。該趟排序從當(dāng)前無(wú)序區(qū)中選出關(guān)鍵字最小的記錄 R[k],將它與無(wú)序區(qū)的第1個(gè)記錄R交換,使R[1..i]和R分別變?yōu)橛涗泜€(gè)數(shù)增加1個(gè)的新有序區(qū)和記錄個(gè)數(shù)減少1個(gè)的新無(wú)序區(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// 儲(chǔ)存最小數(shù)值的索引值   
  25. for (j = i; j < Index; j++) {   
  26. if (a[j] < MinValue) // 找到最小值   
  27. {   
  28. MinValue = a[j]; // 儲(chǔ)存最小值   
  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é)任編輯:于鐵 來(lái)源: 百度
相關(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

插入排序對(duì)象序列log2i

2022-01-06 16:20:04

Java排序算法排序

2021-01-19 07:02:26

算法數(shù)據(jù)結(jié)構(gòu)堆排序
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 久久久久久久久久影视 | 91精品国产一区二区三区动漫 | 中文字幕综合在线 | 国精产品一区一区三区免费完 | 成人国产精品久久 | 五月天婷婷久久 | 黄色毛片免费看 | 国产欧美日韩一区二区三区在线 | 国产精品夜夜夜一区二区三区尤 | 99re超碰| 视频一二三区 | 日韩和的一区二区 | 国产精品国产精品国产专区不片 | 国产精品电影在线观看 | 韩国久久精品 | 黄色大片免费网站 | 国产一区二区在线91 | 午夜大片 | 中文字幕欧美日韩一区 | 国产精品不卡 | 欧美一区二区网站 | 免费毛片在线 | 国产原创视频 | 操视频网站| 91免费福利在线 | 人妖一区 | 99亚洲精品| 欧美中文字幕一区二区三区亚洲 | 97国产精品视频人人做人人爱 | 亚洲一区视频在线播放 | 亚洲视频中文字幕 | 欧美日产国产成人免费图片 | 国产精品激情 | 蜜桃视频在线观看www社区 | 网站黄色在线免费观看 | 国产日韩欧美一区二区在线播放 | 全免费a级毛片免费看视频免 | 高清一区二区三区 | 黑人精品欧美一区二区蜜桃 | 成人高清在线视频 | 一级毛片视频 |