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

Java冒泡排序法和選擇排序法的實(shí)現(xiàn)

 更新時間:2019年09月12日 09:56:43   作者:神經(jīng)大條蕾弟  
這篇文章主要介紹了Java冒泡排序法和選擇排序法的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

冒泡排序法和選擇排序法

本人學(xué)生黨一枚。Java學(xué)習(xí)過程,寫這個博客純屬當(dāng)復(fù)習(xí),有什么錯誤的地方請大家指出來在評論里指點(diǎn)指點(diǎn)我。謝謝

冒泡排序法

概念:

從前向后(或從后向前)依次比較相鄰的元素,若發(fā)現(xiàn)逆順序,則交換。小的向前換,大的向后換,像水底的氣泡逐漸向上冒,顧名思義冒泡排序法。

通俗一點(diǎn)就是把大的往上挪!向冒泡一樣。

是交換式排序法的一種。冒泡排序法效率較低。

冒泡過程

冒泡排序法思路

1:外層循環(huán):控制它要走幾次。
假設(shè)你有5個數(shù),那就要走4次,最后一次不用走,最后那個數(shù)已經(jīng)在它位置了所以就要length-1次。
2:內(nèi)層循環(huán):控制逐一比較,如果發(fā)現(xiàn)前一個數(shù)比后一個數(shù)大,則交換。
注意!因?yàn)樵奖容^長度就越小了,所以長度要length-1-i。

package com.test_1;

public class Demo5_3 {

  public static void main(String[] args) {
    // TODO Auto-generated method stub

    int arr [ ] ={1,6,0,-1,9};
    int temp=0;//中間值
    //-------冒泡排序法
    //外層循環(huán),它決定一共走幾趟
    for(int i = 0;i<arr.length-1;i++){
      //內(nèi)層循環(huán),開始逐個比較
      //如果我們發(fā)現(xiàn)前一個數(shù)比后一個數(shù)大,則交換
      for(int j=0;j<arr.length-1-i;j++){
        if (arr[j]>arr[j+1]) {
          //換位
          temp = arr[j];
          arr[j] = arr[j+1];
          arr[j+1] = temp;
        }
      }

    }
    //輸出結(jié)果
    for(int i = 0;i<arr.length;i++){
      System.out.print(arr[i]);
    }

  }

}

選擇排序法

概念:
第一次從R[0]~R[n-1]中選取最小值,與R[0]交換。第二次從R[1]~R[n-1]中選取最小值與R[1]交換。。。以此類推。
通俗點(diǎn)說就是每次找到后面元素的最小值然后與之交換。
選擇排序法效率中。

選擇排序過程

選擇排序思路
1:外層循環(huán):要走幾趟,同樣是length-1。
2:設(shè)置一個最小值。假設(shè)第一個就是最小值。
3:設(shè)置一個最小值下標(biāo)
4:內(nèi)層循環(huán):那你當(dāng)前的最小值去逐一比較。當(dāng)有比當(dāng)前最小值小的數(shù)時,記錄最小值,記錄下標(biāo)。
5:退出內(nèi)層循環(huán)后就交換位置。

package com.test_1;

public class Demo5_3 {

  public static void main(String[] args) {


    //簡單測試數(shù)組
    int arr [ ] ={1,6,0,-1,9,1000,-1000,98,-687};

    //調(diào)用選擇排序法
    Select select = new Select();
    select.sort(arr);
  }

}


//--------------選擇排序法
class Select{
  public void sort(int arr[]){
    //中間值
    int temp = 0;

    //外循環(huán):我認(rèn)為最小的數(shù),從0~長度-1
    for(int j = 0; j<arr.length-1;j++){
      //最小值:假設(shè)第一個數(shù)就是最小的
      int min = arr[j];
      //記錄最小數(shù)的下標(biāo)的
      int minIndex=j;

      //內(nèi)循環(huán):拿我認(rèn)為的最小的數(shù)和后面的數(shù)一個個進(jìn)行比較
      for(int k=j+1;k<arr.length;k++){
        //找到最小值
        if (min>arr[k]) {
          //修改最小
          min=arr[k];
          minIndex=k;
        }
      }
      //當(dāng)退出內(nèi)層循環(huán)就找到這次的最小值
      //交換位置
      temp = arr[j];
      arr[j]=arr[minIndex];
      arr[minIndex]=temp;
    }
    //輸出結(jié)果
    for(int i = 0;i<arr.length;i++){
      System.out.print(arr[i]+"  ");
    }

  }
}

最后再比較一下兩個排序法之間的效率差異:
代碼

package com.test_1;

import java.util.Calendar;

public class Demo5_3 {

  public static void main(String[] args) {

    //構(gòu)建一個龐大的無序數(shù)組用于測試時間
    int len=100000;
    int arr1 [] = new int [len];
    for(int i=0;i<len;i++){
      //讓程序隨機(jī)產(chǎn)生一個1~10000的數(shù)
      //Math.random()會產(chǎn)生一個0~1的數(shù)
      int t = (int)(Math.random()*10000);
      arr1[i] = t;
    }

    //簡單測試數(shù)組
    int arr [ ] ={1,6,0,-1,9,1000,-1000,98,-687};

    //獲得時間實(shí)例
    Calendar cal = Calendar.getInstance();

    //在排序前打印系統(tǒng)時間
    System.out.println("冒泡排序法開始"+cal.getTime());
    //調(diào)用冒泡排序法
    Bubble bubble = new Bubble();
    bubble.sort(arr1);
    //重新獲得時間實(shí)例
    cal = Calendar.getInstance();
    System.out.println("冒泡排序法結(jié)束"+cal.getTime());


    //重新獲得時間實(shí)例
    cal = Calendar.getInstance();
    System.out.println("選擇排序法開始"+cal.getTime());
    //調(diào)用選擇排序法
    Select select = new Select();
    select.sort(arr1);
    //重新獲得時間實(shí)例
    cal = Calendar.getInstance();
    System.out.println("選擇排序法結(jié)束"+cal.getTime());
  }

}

//-----------------冒泡排序法
class Bubble{
  //排序方法
  public void sort(int arr[]){
    int temp=0;//中間值
    //-------冒泡排序法
    //外層循環(huán),它決定一共走幾趟
    for(int i = 0;i<arr.length-1;i++){
      //內(nèi)層循環(huán),決定每一趟循環(huán)的次數(shù)
      //如果我們發(fā)現(xiàn)前一個數(shù)比后一個數(shù)大,則交換
      for(int j=0;j<arr.length-1-i;j++){
        if (arr[j]>arr[j+1]) {
          //換位
          temp = arr[j];
          arr[j] = arr[j+1];
          arr[j+1] = temp;
        }
      }

    }  
    /*//輸出結(jié)果
        for(int i = 0;i<arr.length;i++){
          System.out.print(arr[i]+"  ");
        }*/
  }  
}


//--------------選擇排序法
class Select
{
  public void sort(int arr[])
  {
    //中間值
    int temp = 0;

    //外循環(huán):我認(rèn)為最小的數(shù),從0~長度-1
    for(int j = 0; j<arr.length-1;j++)
    {
      //最小值:假設(shè)第一個數(shù)就是最小的
      int min = arr[j];
      //記錄最小數(shù)的下標(biāo)的
      int minIndex=j;

      //內(nèi)循環(huán):拿我認(rèn)為的最小的數(shù)和后面的數(shù)一個個進(jìn)行比較找到下標(biāo)
      for(int k=j+1;k<arr.length;k++)
      {
        //找到最小值
        if (min>arr[k]) 
        {
          //修改最小
          min=arr[k];
          minIndex=k;
        }
      }
      //當(dāng)退出內(nèi)層循環(huán)就找到這次的最小值
      //交換位置
      temp = arr[j];
      arr[j]=arr[minIndex];
      arr[minIndex]=temp;
    }
    /*//輸出結(jié)果
    for(int i = 0;i<arr.length;i++){
      System.out.print(arr[i]+"  ");
    }*/

  }
}

運(yùn)行結(jié)果:

運(yùn)行結(jié)果:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Spring?Boot中記錄用戶系統(tǒng)操作流程

    Spring?Boot中記錄用戶系統(tǒng)操作流程

    這篇文章主要介紹了如何在Spring?Boot中記錄用戶系統(tǒng)操作流程,將介紹如何在Spring?Boot中使用AOP(面向切面編程)和日志框架來實(shí)現(xiàn)用戶系統(tǒng)操作流程的記錄,需要的朋友可以參考下
    2023-07-07
  • Java使用poi-tl1.9.1生成Word文檔的技巧分享

    Java使用poi-tl1.9.1生成Word文檔的技巧分享

    本文將簡單介紹poi-tl的相關(guān)知識,通過一個實(shí)際的案例實(shí)踐,充分介紹如何利用poi-tl進(jìn)行目標(biāo)文檔的生成,同時分享幾個不同的office版本如何進(jìn)行圖表生成的解決方案,需要的朋友可以參考下
    2023-09-09
  • Spring的RequestBodyAdvice攔截淺析

    Spring的RequestBodyAdvice攔截淺析

    本文主要介紹了Spring的RequestBodyAdvice攔截淺析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • Java非侵入式API接口文檔工具apigcc用法詳解

    Java非侵入式API接口文檔工具apigcc用法詳解

    這篇文章主要介紹了Java非侵入式API接口文檔工具apigcc用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • 使用@RequestBody傳遞多個不同對象方式

    使用@RequestBody傳遞多個不同對象方式

    這篇文章主要介紹了使用@RequestBody傳遞多個不同對象方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java死鎖代碼實(shí)例及產(chǎn)生死鎖必備的四個條件

    Java死鎖代碼實(shí)例及產(chǎn)生死鎖必備的四個條件

    這篇文章主要介紹了Java死鎖代碼實(shí)例及產(chǎn)生死鎖必備的四個條件,Java 發(fā)生死鎖的根本原因是,在申請鎖時發(fā)生了交叉閉環(huán)申請,synchronized在開發(fā)中最好不要嵌套使用,容易導(dǎo)致死鎖,需要的朋友可以參考下
    2024-01-01
  • JAVA集合框架專題

    JAVA集合框架專題

    這篇文章主要介紹了JAVA集合框架的相關(guān)知識,文中講解非常細(xì)致,幫助大家更好的理解學(xué)習(xí)JAVA框架,感興趣的朋友快來了解下
    2020-06-06
  • JAVA 對50取余數(shù)的五種方法試下

    JAVA 對50取余數(shù)的五種方法試下

    在數(shù)學(xué)計(jì)算中經(jīng)常會遇到余數(shù),本文主要介紹了JAVA 對50取余數(shù)的五種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-03-03
  • java中extends與implements的區(qū)別淺談

    java中extends與implements的區(qū)別淺談

    java中extends與implements的區(qū)別淺談,需要的朋友可以參考一下
    2013-03-03
  • java.sql.Date和java.util.Date的區(qū)別詳解

    java.sql.Date和java.util.Date的區(qū)別詳解

    Java中有兩個Date類,一個是java.util.Date通常情況下用它獲取當(dāng)前時間或構(gòu)造時間,另一個是java.sql.Date是針對SQL語句使用的,它只包含日期而沒有時間部分,這篇文章主要給大家介紹了關(guān)于java.sql.Date和java.util.Date區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2023-03-03

最新評論