真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Java中怎么實現(xiàn)冒泡排序法和選擇排序法

Java中怎么實現(xiàn)冒泡排序法和選擇排序法,相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

專注于為中小企業(yè)提供網(wǎng)站設計、成都網(wǎng)站設計服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)彭澤免費做網(wǎng)站提供優(yōu)質的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了成百上千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉變。

冒泡排序法

概念:

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

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

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

冒泡排序法思路

1:外層循環(huán):控制它要走幾次。 假設你有5個數(shù),那就要走4次,最后一次不用走,最后那個數(shù)已經(jīng)在它位置了所以就要length-1次。 2:內層循環(huán):控制逐一比較,如果發(fā)現(xiàn)前一個數(shù)比后一個數(shù)大,則交換。 注意!因為越比較長度就越小了,所以長度要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;iarr[j+1]) {          //換位          temp = arr[j];          arr[j] = arr[j+1];          arr[j+1] = temp;        }      }    }    //輸出結果    for(int i = 0;i

選擇排序法

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

選擇排序思路1:外層循環(huán):要走幾趟,同樣是length-1。 2:設置一個最小值。假設第一個就是最小值。 3:設置一個最小值下標 4:內層循環(huán):那你當前的最小值去逐一比較。當有比當前最小值小的數(shù)時,記錄最小值,記錄下標。 5:退出內層循環(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};    //調用選擇排序法    Select select = new Select();    select.sort(arr);  }}//--------------選擇排序法class Select{  public void sort(int arr[]){    //中間值    int temp = 0;    //外循環(huán):我認為最小的數(shù),從0~長度-1    for(int j = 0; jarr[k]) {          //修改最小          min=arr[k];          minIndex=k;        }      }      //當退出內層循環(huán)就找到這次的最小值      //交換位置      temp = arr[j];      arr[j]=arr[minIndex];      arr[minIndex]=temp;    }    //輸出結果    for(int i = 0;i

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

package com.test_1;import java.util.Calendar;public class Demo5_3 {  public static void main(String[] args) {    //構建一個龐大的無序數(shù)組用于測試時間    int len=100000;    int arr1 [] = new int [len];    for(int i=0;iarr[j+1]) {          //換位          temp = arr[j];          arr[j] = arr[j+1];          arr[j+1] = temp;        }      }    }      /*//輸出結果        for(int i = 0;iarr[k])         {          //修改最小          min=arr[k];          minIndex=k;        }      }      //當退出內層循環(huán)就找到這次的最小值      //交換位置      temp = arr[j];      arr[j]=arr[minIndex];      arr[minIndex]=temp;    }    /*//輸出結果    for(int i = 0;i

看完上述內容,你們掌握Java中怎么實現(xiàn)冒泡排序法和選擇排序法的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!


網(wǎng)站名稱:Java中怎么實現(xiàn)冒泡排序法和選擇排序法
文章URL:http://weahome.cn/article/ppsgeg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部