亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

JAVA簡單選擇排序算法原理及實現

2019-11-26 15:45:35
字體:
來源:轉載
供稿:網友

簡單選擇排序:(選出最小值,放在第一位,然后第一位向后推移,如此循環)第一位與后面每一個逐個比較,每次都使最小的置頂,第一位向后推進(即剛選定的第一位是最小值,不再參與比較,比較次數減1)

復雜度: 所需進行記錄移動的操作次數較少 0--3(n-1) ,無論記錄的初始排列如何,所需的關鍵字間的比較次數相同,均為n(n-1)/2,總的時間復雜度為O(n2);
空間復雜度 O(1)

算法改進:每次對比,都是為了將最小的值放到第一位,所以可以一比到底,找出最小值,直接放到第一位,省去無意義的調換移動操作。也可以換一個方向,最后一位與前面每一個比較,每次使最大值沉底,最后一位向前推進。

JAVA源代碼:

復制代碼 代碼如下:

 public static void selectSort(Date[] days) {
  int min;
  Date temp;
  for (int i = 0; i < days.length; i++) {
   min = i;
   for (int j = min + 1; j < days.length; j++) {
    if (days[min].compare(days[j]) > 0) {
     min = j;
    }
   }
   if (min != i) {
    temp = days[i];
    days[i] = days[min];
    days[min] = temp;
   }
  }
 }
class Date {
 int year, month, day;

 Date(int y, int m, int d) {
  year = y;
  month = m;
  day = d;
 }

 public int compare(Date date) {
  return year > date.year ? 1 : year < date.year ? -1
    : month > date.month ? 1 : month < date.month ? -1
      : day > date.day ? 1 : day < date.day ? -1 : 0;
 }

 public void print() {
  System.out.println(year + " " + month + " " + day);
 }
}


  簡單選擇排序(Simple Selection Sort):

  簡單選擇排序類似于冒泡排序(Bubble Sort) ,每次都會在剩下的元素集合中選擇出一個最值出來填充到當前位置。唯一的區別是,冒泡排序在每次發現比當前值小于(或大于)時,都會交換元素的位置, 而 簡單選擇排序是選擇剩余元素中的最值和當前位置交換數據。

  比如對于元素集合R={37, 40, 38, 42, 461, 5,  7, 9, 12}

  在第一趟排序中:37直接和5交換, 形成新的序列 R1={5,40,38,42,461,37,7,9,12}
  在第二趟排序中:40直接和7交換, 形成新的序列 R2={5,7,38,42,461,37,40,9,12}

  以此類推,直到最后一個元素(注意:在第二趟排序中,38比42小,但是他們并沒有交換數據)。

  以下是簡單選擇排序的一個Java實現版本:

復制代碼 代碼如下:

  public static void selectionSort(int[] data) {
  if (data == null || data.length <= 1)
  return;
  int i, j, value, minPos, len = data.length;
  int outer = len - 1, tmp;
  for (i = 0; i < outer; i++) {
  value = data[i];
  minPos = -1;
  for (j = i + 1; j < len; j++) {
  if (data[j] < value) {
  minPos = j;
  value = data[j];
  }
  }
  if (minPos != -1) {
  tmp = data[i];
  data[i] = value;
  data[minPos] = tmp;
  }
  //            for (int k = 0; k < len; k++) {
  //                System.out.print(data[k] + " , ");
  //            }
  //            System.out.println();
  }
  }
  public static void main(String[] args) {
  int[] coll = {
  37, 40, 38, 42, 461, 5,  7, 9, 12
  };
  selectionSort(coll);
  for (int i = 0; i < coll.length; i++) {
  System.out.print(coll[i] + " , ");
  }
  }

  樹選擇排序(Tree Selection Sort)
  樹選擇排序算法相對于簡單選擇排序來說是典型的以空間換時間的算法。其思想是對待排序的 N 個元素 , 構造出相對較小的 (n+1)/2個數,然后再構造出相對較小的[n+1]/4個數,直到只有一個元素為止。構造成一個完全二叉樹。
  排序的時候,那個元素就是最小的,取出該最小元素,將該元素替換為"最大值",再調整完全二叉樹。
下面是樹形選擇排序的一個Java實現版:

復制代碼 代碼如下:

  public static void treeSelectionSort(int[] data) {
  if (data == null || data.length <= 1)
  return;
  int len = data.length , low = 0 , i , j;
  // add Auxiliary Space
  int[] tmp = new int[2*len -1];
  int tSize = tmp.length;
  //construct a tree
  for(i =len-1 , j=tmp.length-1;i >=0 ;i--,j--){
  tmp[j]=data[i];
  }
  for(i = tSize -1 ; i > 0 ; i-=2){
  tmp[(i-1)/2] = tmp[i] > tmp[i-1]? tmp[i-1]:tmp[i];
  }
  //end
  //remove the minimum node.
  while(low < len){
  data[low++] = tmp[0];
  for(j=tSize-1;tmp[j]!=tmp[0];j--);
  tmp[j] = Integer.MAX_VALUE;
  while(j > 0){
  if(j%2 == 0){  //如果是右節點
  tmp[(j-1)/2] = tmp[j] > tmp[j-1]?tmp[j-1]:tmp[j];
  j = (j-1)/2;
  }else{  //如果是左節點
  tmp[j/2]=tmp[j] > tmp[j+1]? tmp[j+1]:tmp[j];
  j = j/2;
  }
  }
  }
  }

  在構造完全二叉樹的時候對 N 個元素的集合, 需要 2*N -1 個輔助空間。
  代碼:

復制代碼 代碼如下:

  while(j > 0){
  if(j%2 == 0){  //如果是右節點
  tmp[(j-1)/2] = tmp[j] > tmp[j-1]?tmp[j-1]:tmp[j];
  j = (j-1)/2;
  }else{  //如果是左節點
  tmp[j/2]=tmp[j] > tmp[j+1]? tmp[j+1]:tmp[j];
  j = j/2;
  }
  }

  則實現遞歸的構造新集合中的最小值。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩中文综合网| 精品一区二区三区三区| 国产一区二区三区视频在线观看| 日韩风俗一区 二区| 欧美大尺度在线观看| 日韩在线视频国产| 麻豆国产精品va在线观看不卡| 大荫蒂欧美视频另类xxxx| 国产精品视频免费观看www| 欧美性视频在线| 久久成人av网站| 秋霞av国产精品一区| 久久精品成人一区二区三区| www.久久草.com| 久久国产天堂福利天堂| 久久国产精品久久久久久久久久| 亚洲第一福利网| 国产精品永久免费观看| 欧美一级视频一区二区| 亚洲国产精品福利| 欧美一级片一区| 欧美精品日韩三级| 68精品久久久久久欧美| 色青青草原桃花久久综合| 久久国产精品久久久久久| 欧美激情一二区| 亚洲最大的网站| 狠狠躁夜夜躁人人爽超碰91| 91午夜理伦私人影院| 亚洲国产另类 国产精品国产免费| 国产成人精品免费久久久久| 亚洲三级黄色在线观看| 日韩免费在线播放| 欧美精品一二区| 伊人青青综合网站| 精品无人区乱码1区2区3区在线| 色多多国产成人永久免费网站| 欧美精品做受xxx性少妇| 欧美日在线观看| 欧美性猛交xxxx免费看| 国产精品久久久久77777| 亚洲影院色在线观看免费| 欧美成人在线免费视频| 中文字幕久久亚洲| 欧美日韩国产在线看| 日韩少妇与小伙激情| 国产精品自产拍在线观看| 国产精品久久久久久久9999| 欧美日韩综合视频| 91欧美精品成人综合在线观看| 欧美做受高潮1| 欧美激情免费视频| 亚洲va久久久噜噜噜久久天堂| 精品久久久久久久久久ntr影视| 久久影院模特热| 国内精品在线一区| 日韩电影大片中文字幕| 欧美性理论片在线观看片免费| 91在线免费看网站| 久久精品久久久久久| 精品久久久国产精品999| 国产精品久久久久久久久| 欧美激情精品久久久| 日韩一区二区在线视频| 午夜精品久久久久久99热软件| 国产成人精品在线播放| 日韩激情片免费| 九九热在线精品视频| 精品国偷自产在线视频99| 欧美香蕉大胸在线视频观看| 欧美高清电影在线看| 久久久久北条麻妃免费看| 精品国产一区二区在线| 久久激情五月丁香伊人| 色偷偷综合社区| 亚洲国产小视频| 91在线无精精品一区二区| 久久亚洲精品一区二区| 国产男人精品视频| 日韩在线精品视频| 欧美视频13p| 国内精品久久久久久久| 日韩美女视频中文字幕| 久久久免费高清电视剧观看| 国产偷亚洲偷欧美偷精品| 久久精品视频网站| 久久久精品国产亚洲| 日韩精品在线视频美女| 91久久久在线| 日韩精品福利网站| 97在线看免费观看视频在线观看| 亚洲a在线播放| 久久精品国产成人精品| 深夜福利国产精品| 亚洲级视频在线观看免费1级| 色综久久综合桃花网| 91精品国产91久久久| 日韩精品中文字幕在线播放| 欧美一区二区色| 91精品视频在线播放| 欧美小视频在线观看| 青青久久av北条麻妃黑人| 久久精品国产一区| 亚洲2020天天堂在线观看| 欧美电影免费观看大全| 91视频国产精品| 久久九九热免费视频| 亚洲高清免费观看高清完整版| 欧美日韩国产在线看| 日韩精品日韩在线观看| 久久久久久久电影一区| 国内揄拍国内精品| 国产精品一区二区三区成人| 岛国视频午夜一区免费在线观看| 国产精品小说在线| 精品亚洲一区二区三区在线播放| 91精品国产沙发| 日韩一区二区三区在线播放| 成人网址在线观看| 国产精品91久久| 97在线观看免费| 欧美日韩激情网| 成人精品一区二区三区电影黑人| 日韩欧美亚洲范冰冰与中字| 成人激情视频在线播放| 亚洲国产日韩欧美综合久久| 亚洲午夜av电影| 91在线看www| 91av成人在线| 精品久久久久久中文字幕大豆网| 国产精品欧美日韩一区二区| 91久久久久久久久久久久久| 在线播放国产精品| 成人激情视频免费在线| 9.1国产丝袜在线观看| 久久亚洲精品国产亚洲老地址| 亚洲3p在线观看| 欧美高清视频在线观看| 日韩精品在线观看网站| 国产成人a亚洲精品| www.日韩av.com| 亚洲激情国产精品| 98精品国产自产在线观看| 美女av一区二区三区| 欧美成人性色生活仑片| 国产亚洲成精品久久| 国产精品久久久久久久久久三级| 国产99视频在线观看| www.欧美视频| 成人av番号网| 久久天天躁夜夜躁狠狠躁2022| 亚洲激情电影中文字幕| 国产亚洲精品久久久久久牛牛| 亚洲欧美日韩中文在线制服| 欧美日韩另类在线| 久久夜色精品亚洲噜噜国产mv| 久久久在线免费观看| 97热在线精品视频在线观看| 在线性视频日韩欧美| 成人性生交大片免费看小说| 欧美乱大交做爰xxxⅹ性3| 日韩欧美在线视频免费观看| 日韩av色在线| 91精品国产一区|