欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實(shí)現(xiàn)選擇排序算法的實(shí)例教程

 更新時(shí)間:2016年05月04日 15:19:32   作者:飛翔的貓咪  
這篇文章主要介紹了Java實(shí)現(xiàn)選擇排序算法的實(shí)例教程,選擇排序的時(shí)間復(fù)雜度為О(n²),需要的朋友可以參考下

選擇排序概念

選擇排序也是一種交換排序算法,和冒泡排序有一定的相似度,因此個(gè)人認(rèn)為選擇排序可以視為冒泡排序的一種改進(jìn)算法。它的思路是這樣的:
設(shè)現(xiàn)在要給數(shù)組arr[]排序,它有n個(gè)元素。
1對(duì)第一個(gè)元素(Java中,下標(biāo)為0)和第二個(gè)元素進(jìn)行比較,如果前者大于后者,那么它一定不是最小的,但是我們并不像冒泡排序一樣急著交換。我們可以設(shè)置一個(gè)臨時(shí)變量a,存儲(chǔ)這個(gè)目前最小的元素的下標(biāo)。然后我們把這個(gè)目前最小的元素繼續(xù)和第三個(gè)元素做比較,如果它仍不是最小的,那么,我們?cè)傩薷腶的值。如此直到和最后一個(gè)元素比較完,可以肯定a存儲(chǔ)的一定是最小的元素的下標(biāo)。
2.如果a的值不為0(初始值,即第一個(gè)元素的下標(biāo)),交換下標(biāo)為a和0的兩個(gè)元素。
3.重復(fù)上述過(guò)程,這次從下標(biāo)為1的元素開(kāi)始比較,因?yàn)橄聵?biāo)為0的位置已經(jīng)放好了最小的元素了。
4.如此直到只剩下最后一個(gè)元素,可以肯定這個(gè)元素就是最大的了。
5.排序完成。
很顯然,這個(gè)算法也需要n-1輪排序。
需要注意的是,以上闡述的只是每次找最小值的辦法。實(shí)際上也可以每次找最大值,不過(guò)那就需要每次放到數(shù)組尾巴上了。

Java實(shí)現(xiàn)代碼:
SelectArray.java

package ch02;

public class SelectArray {
  // 數(shù)組
  private long[] arr;

  // 數(shù)組中有效數(shù)據(jù)的大小
  private int elems;

  // 默認(rèn)構(gòu)造函數(shù)
  public SelectArray() {
    arr = new long[50];
  }

  public SelectArray(int max) {
    arr = new long[max];
  }

  // 插入數(shù)據(jù)
  public void insert(long value) {
    arr[elems] = value;
    elems++;
  }

  // 顯示數(shù)據(jù)
  public void display() {
    for (int i = 0; i < elems; i++) {
      System.out.print(arr[i] + " ");
    }
    System.out.println();
  }

  // 選擇排序
  public void selectSort(){
    int min = 0;
    long tmp = 0L;
    for(int i = 0; i < elems -1; i++){
      min = i;
      for(int j = i + 1; j < elems; j++) {
        if(arr[j] < arr[min]) {
          min = j;
        }
      }
      tmp = arr[i];
      arr[i] = arr[min];
      arr[min] = tmp;
    }
  }
}

測(cè)試代碼:

package ch02;

public class TestSelectArray {

  public static void main(String[] args) {
    SelectArray sArr = new SelectArray();
    sArr.insert(89);
    sArr.insert(54);
    sArr.insert(667);
    sArr.insert(7);
    sArr.insert(12);
    sArr.insert(43);
    sArr.insert(12);

    sArr.display();
    sArr.selectSort();
    sArr.display();

  }

}

結(jié)果:

201654151524688.png (513×126)

相關(guān)文章

  • 使用RedisAtomicLong優(yōu)化性能問(wèn)題

    使用RedisAtomicLong優(yōu)化性能問(wèn)題

    這篇文章主要介紹了使用RedisAtomicLong優(yōu)化性能問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • 網(wǎng)關(guān)Gateway過(guò)濾器的使用詳解

    網(wǎng)關(guān)Gateway過(guò)濾器的使用詳解

    Gateway網(wǎng)關(guān)的過(guò)濾器分為兩種,一種是局部過(guò)濾器,一種是全局過(guò)濾器,過(guò)濾器就是過(guò)濾一些請(qǐng)求,在這里,全局過(guò)濾器的作用是處理一切進(jìn)入網(wǎng)關(guān)的請(qǐng)求和微服務(wù)響應(yīng),與GatewayFilter的作用一樣,本文給大家介紹網(wǎng)關(guān)Gateway過(guò)濾器的使用,感興趣的朋友一起看看吧
    2022-07-07
  • Gson中的TypeToken與泛型擦除詳情

    Gson中的TypeToken與泛型擦除詳情

    這篇文章主要介紹了Gson中的TypeToken與泛型擦除詳情,其Gson類提供了toJson()與fromJson()方法,分別用來(lái)序列化與反序列化,更多相關(guān)內(nèi)容需要的朋友可以參考一下
    2022-09-09
  • Java Map.getOrDefault方法詳解

    Java Map.getOrDefault方法詳解

    Map.getOrDefault(Object key, V defaultValue)是Java中Map接口的一個(gè)方法,用于獲取指定鍵對(duì)應(yīng)的值,如果鍵不存在,則返回一個(gè)默認(rèn)值,這篇文章主要介紹了Java Map.getOrDefault方法詳解,需要的朋友可以參考下
    2024-01-01
  • MyBatis中$和#的深入講解

    MyBatis中$和#的深入講解

    這篇文章主要給大家介紹了關(guān)于MyBatis中$和#的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • SpringBoot多controller添加URL前綴的實(shí)現(xiàn)方法

    SpringBoot多controller添加URL前綴的實(shí)現(xiàn)方法

    這篇文章主要介紹了SpringBoot多controller添加URL前綴的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • Java創(chuàng)建數(shù)組的幾種方式總結(jié)

    Java創(chuàng)建數(shù)組的幾種方式總結(jié)

    下面小編就為大家?guī)?lái)一篇Java創(chuàng)建數(shù)組的幾種方式總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • Java中public關(guān)鍵字用法詳細(xì)講解

    Java中public關(guān)鍵字用法詳細(xì)講解

    這篇文章主要給大家介紹了關(guān)于Java中public關(guān)鍵字用法的相關(guān)資料,public關(guān)鍵字是和訪問(wèn)權(quán)限相關(guān)的,它所修飾的方法對(duì)所有類都是可以訪問(wèn)的,需要的朋友可以參考下
    2023-09-09
  • java無(wú)限遞歸遍歷json對(duì)象問(wèn)題

    java無(wú)限遞歸遍歷json對(duì)象問(wèn)題

    這篇文章主要介紹了java無(wú)限遞歸遍歷json對(duì)象問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 使用springBoot中的info等級(jí)通過(guò)druid打印sql

    使用springBoot中的info等級(jí)通過(guò)druid打印sql

    這篇文章主要介紹了使用springBoot中的info等級(jí)通過(guò)druid打印sql,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09

最新評(píng)論