亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

Java中怎么實現冒泡排序法和選擇排序法

發布時間:2021-08-07 14:35:13 來源:億速云 閱讀:88 作者:Leah 欄目:編程語言

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

選擇排序思路 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

文昌市| 依兰县| 呼玛县| 尚义县| 高碑店市| 临猗县| 延吉市| 西吉县| 裕民县| 元阳县| 象州县| 彝良县| 惠水县| 上虞市| 策勒县| 太湖县| 翁牛特旗| 长阳| 忻州市| 晋江市| 偃师市| 溆浦县| 天门市| 江永县| 缙云县| 临猗县| 平安县| 昌都县| 蕉岭县| 中牟县| 宜兴市| 博客| 阿坝县| 马尔康县| 九江县| 榆社县| 巴林右旗| 怀柔区| 瓮安县| 乌海市| 青浦区|