Java實現(xiàn)選擇排序算法的實例教程
選擇排序概念
選擇排序也是一種交換排序算法,和冒泡排序有一定的相似度,因此個人認(rèn)為選擇排序可以視為冒泡排序的一種改進(jìn)算法。它的思路是這樣的:
設(shè)現(xiàn)在要給數(shù)組arr[]排序,它有n個元素。
1對第一個元素(Java中,下標(biāo)為0)和第二個元素進(jìn)行比較,如果前者大于后者,那么它一定不是最小的,但是我們并不像冒泡排序一樣急著交換。我們可以設(shè)置一個臨時變量a,存儲這個目前最小的元素的下標(biāo)。然后我們把這個目前最小的元素繼續(xù)和第三個元素做比較,如果它仍不是最小的,那么,我們再修改a的值。如此直到和最后一個元素比較完,可以肯定a存儲的一定是最小的元素的下標(biāo)。
2.如果a的值不為0(初始值,即第一個元素的下標(biāo)),交換下標(biāo)為a和0的兩個元素。
3.重復(fù)上述過程,這次從下標(biāo)為1的元素開始比較,因為下標(biāo)為0的位置已經(jīng)放好了最小的元素了。
4.如此直到只剩下最后一個元素,可以肯定這個元素就是最大的了。
5.排序完成。
很顯然,這個算法也需要n-1輪排序。
需要注意的是,以上闡述的只是每次找最小值的辦法。實際上也可以每次找最大值,不過那就需要每次放到數(shù)組尾巴上了。
Java實現(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;
}
}
}
測試代碼:
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)文章
SpringBoot多controller添加URL前綴的實現(xiàn)方法
這篇文章主要介紹了SpringBoot多controller添加URL前綴的方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-02-02
Java創(chuàng)建數(shù)組的幾種方式總結(jié)
下面小編就為大家?guī)硪黄狫ava創(chuàng)建數(shù)組的幾種方式總結(jié)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10
Java中public關(guān)鍵字用法詳細(xì)講解
這篇文章主要給大家介紹了關(guān)于Java中public關(guān)鍵字用法的相關(guān)資料,public關(guān)鍵字是和訪問權(quán)限相關(guān)的,它所修飾的方法對所有類都是可以訪問的,需要的朋友可以參考下2023-09-09
使用springBoot中的info等級通過druid打印sql
這篇文章主要介紹了使用springBoot中的info等級通過druid打印sql,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09

