中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用Java怎么實現一個冒泡排序法和選擇排序法

發布時間:2021-04-17 17:59:02 來源:億速云 閱讀:227 作者:Leah 欄目:編程語言

使用Java怎么實現一個冒泡排序法和選擇排序法?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

冒泡排序法

概念:

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

通俗一點就是把大的往上挪!向冒泡一樣。

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

使用Java怎么實現一個冒泡排序法和選擇排序法

冒泡排序法思路

1:外層循環:控制它要走幾次。
假設你有5個數,那就要走4次,最后一次不用走,最后那個數已經在它位置了所以就要length-1次。
2:內層循環:控制逐一比較,如果發現前一個數比后一個數大,則交換。
注意!因為越比較長度就越小了,所以長度要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;//中間值
    //-------冒泡排序法
    //外層循環,它決定一共走幾趟
    for(int i = 0;i<arr.length-1;i++){
      //內層循環,開始逐個比較
      //如果我們發現前一個數比后一個數大,則交換
      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;
        }
      }

    }
    //輸出結果
    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]交換。。。以此類推。
通俗點說就是每次找到后面元素的最小值然后與之交換。
選擇排序法效率中。

使用Java怎么實現一個冒泡排序法和選擇排序法

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

package com.test_1;

public class Demo5_3 {

  public static void main(String[] args) {


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

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

}


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

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

      //內循環:拿我認為的最小的數和后面的數一個個進行比較
      for(int k=j+1;k<arr.length;k++){
        //找到最小值
        if (min>arr[k]) {
          //修改最小
          min=arr[k];
          minIndex=k;
        }
      }
      //當退出內層循環就找到這次的最小值
      //交換位置
      temp = arr[j];
      arr[j]=arr[minIndex];
      arr[minIndex]=temp;
    }
    //輸出結果
    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) {

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

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

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

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


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

}

//-----------------冒泡排序法
class Bubble{
  //排序方法
  public void sort(int arr[]){
    int temp=0;//中間值
    //-------冒泡排序法
    //外層循環,它決定一共走幾趟
    for(int i = 0;i<arr.length-1;i++){
      //內層循環,決定每一趟循環的次數
      //如果我們發現前一個數比后一個數大,則交換
      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;
        }
      }

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


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

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

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

  }
}

運行結果:

使用Java怎么實現一個冒泡排序法和選擇排序法

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东安县| 屏东县| 邻水| 隆安县| 新沂市| 铁岭市| 黔东| 峨眉山市| 新民市| 比如县| 门源| 礼泉县| 新建县| 始兴县| 特克斯县| 湾仔区| 基隆市| 雷波县| 叶城县| 额尔古纳市| 禄丰县| 华亭县| 时尚| 藁城市| 汾阳市| 洪洞县| 页游| 万盛区| 兴化市| 井陉县| 江津市| 新密市| 唐山市| 万州区| 安泽县| 广元市| 隆化县| 天门市| 山西省| 贵州省| 佛坪县|