選擇排序之java實現

來源:互聯網
上載者:User

選擇排序也是比較簡單的一種排序方法,原理也比較容易理解,它與冒泡排序的比較次數相同,但選擇排序的交換次數少於冒泡排序。冒泡排序是在每次比較之後,若比較的兩個元素順序與待排序次序相反,則要進行交換,而選擇排序在每次遍曆過程中只記錄下來最小的一個元素的下標,待全部比較結束之後,將最小的元素與未排序的那部分序列的最前面一個元素交換,這樣就降低了交換的次數,提高了排序效率。

java實現的代碼如下:

public class ChoseSort {//constructor without parameterspublic ChoseSort(){};//constructor with parameterspublic int[] ChoseSort(int[] intArr){for(int i=0;i<intArr.length;i++){int lowIndex = i;for(int j=i+1;j<intArr.length;j++){if(intArr[j]<intArr[lowIndex]){lowIndex = j;}}//將當前第一個元素與它後面序列中的最小的一個 元素交換,也就是將最小的元素放在最前端int temp = intArr[i];intArr[i] = intArr[lowIndex];intArr[lowIndex] = temp;}return intArr;}public static void main(String[] args) {ChoseSort choseSort = new ChoseSort();int[] intArr = {5,6,9,2,4,3,8};int[] intArrAfterSort = choseSort.ChoseSort(intArr);for(int arrItem:intArrAfterSort){System.out.print(arrItem+" ");}}}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.