Java實(shí)現(xiàn)選擇排序算法的實(shí)例教程
選擇排序概念
選擇排序也是一種交換排序算法,和冒泡排序有一定的相似度,因此個(gè)人認(rèn)為選擇排序可以視為冒泡排序的一種改進(jìn)算法。它的思路是這樣的:
設(shè)現(xiàn)在要給數(shù)組arr[]排序,它有n個(gè)元素。
1對(duì)第一個(gè)元素(Java中,下標(biāo)為0)和第二個(gè)元素進(jìn)行比較,如果前者大于后者,那么它一定不是最小的,但是我們并不像冒泡排序一樣急著交換。我們可以設(shè)置一個(gè)臨時(shí)變量a,存儲(chǔ)這個(gè)目前最小的元素的下標(biāo)。然后我們把這個(gè)目前最小的元素繼續(xù)和第三個(gè)元素做比較,如果它仍不是最小的,那么,我們?cè)傩薷腶的值。如此直到和最后一個(gè)元素比較完,可以肯定a存儲(chǔ)的一定是最小的元素的下標(biāo)。
2.如果a的值不為0(初始值,即第一個(gè)元素的下標(biāo)),交換下標(biāo)為a和0的兩個(gè)元素。
3.重復(fù)上述過(guò)程,這次從下標(biāo)為1的元素開(kāi)始比較,因?yàn)橄聵?biāo)為0的位置已經(jīng)放好了最小的元素了。
4.如此直到只剩下最后一個(gè)元素,可以肯定這個(gè)元素就是最大的了。
5.排序完成。
很顯然,這個(gè)算法也需要n-1輪排序。
需要注意的是,以上闡述的只是每次找最小值的辦法。實(shí)際上也可以每次找最大值,不過(guò)那就需要每次放到數(shù)組尾巴上了。
Java實(shí)現(xiàn)代碼:
SelectArray.java
package ch02; public class SelectArray { // 數(shù)組 private long[] arr; // 數(shù)組中有效數(shù)據(jù)的大小 private int elems; // 默認(rèn)構(gòu)造函數(shù) public SelectArray() { arr = new long[50]; } public SelectArray(int max) { arr = new long[max]; } // 插入數(shù)據(jù) public void insert(long value) { arr[elems] = value; elems++; } // 顯示數(shù)據(jù) public void display() { for (int i = 0; i < elems; i++) { System.out.print(arr[i] + " "); } System.out.println(); } // 選擇排序 public void selectSort(){ int min = 0; long tmp = 0L; for(int i = 0; i < elems -1; i++){ min = i; for(int j = i + 1; j < elems; j++) { if(arr[j] < arr[min]) { min = j; } } tmp = arr[i]; arr[i] = arr[min]; arr[min] = tmp; } } }
測(cè)試代碼:
package ch02; public class TestSelectArray { public static void main(String[] args) { SelectArray sArr = new SelectArray(); sArr.insert(89); sArr.insert(54); sArr.insert(667); sArr.insert(7); sArr.insert(12); sArr.insert(43); sArr.insert(12); sArr.display(); sArr.selectSort(); sArr.display(); } }
結(jié)果:
相關(guān)文章
使用RedisAtomicLong優(yōu)化性能問(wèn)題
這篇文章主要介紹了使用RedisAtomicLong優(yōu)化性能問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11網(wǎng)關(guān)Gateway過(guò)濾器的使用詳解
Gateway網(wǎng)關(guān)的過(guò)濾器分為兩種,一種是局部過(guò)濾器,一種是全局過(guò)濾器,過(guò)濾器就是過(guò)濾一些請(qǐng)求,在這里,全局過(guò)濾器的作用是處理一切進(jìn)入網(wǎng)關(guān)的請(qǐng)求和微服務(wù)響應(yīng),與GatewayFilter的作用一樣,本文給大家介紹網(wǎng)關(guān)Gateway過(guò)濾器的使用,感興趣的朋友一起看看吧2022-07-07SpringBoot多controller添加URL前綴的實(shí)現(xiàn)方法
這篇文章主要介紹了SpringBoot多controller添加URL前綴的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-02-02Java創(chuàng)建數(shù)組的幾種方式總結(jié)
下面小編就為大家?guī)?lái)一篇Java創(chuàng)建數(shù)組的幾種方式總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10Java中public關(guān)鍵字用法詳細(xì)講解
這篇文章主要給大家介紹了關(guān)于Java中public關(guān)鍵字用法的相關(guān)資料,public關(guān)鍵字是和訪問(wèn)權(quán)限相關(guān)的,它所修飾的方法對(duì)所有類都是可以訪問(wèn)的,需要的朋友可以參考下2023-09-09java無(wú)限遞歸遍歷json對(duì)象問(wèn)題
這篇文章主要介紹了java無(wú)限遞歸遍歷json對(duì)象問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07使用springBoot中的info等級(jí)通過(guò)druid打印sql
這篇文章主要介紹了使用springBoot中的info等級(jí)通過(guò)druid打印sql,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09