選擇排序的另一種思路

在我們上次的選擇循環中,我們用了一個minIndex變量來儲存最小值的下標,每次循環完畢後用最小值下標的元素與手元素進行交換,

遍歷一次,記錄下最值元素所在位置,遍歷結束後,將此最值元素調整到合適的位置。


但是我們還有種交換變量的方式,我們可以用待排序數組中的元素與待排序序列中的首元素比較,如果比待排序數列中的首元素小,就對他們進行交換,循環結束後首元素即是這段未排序序列中的最小值,下面貼出代碼


public class Demo2 {

	public static void main(String[] args) {
		int[] arr = {55,95,45,21,65,45,25,48,62,66,75};
		
		for (int i = 0; i < arr.length - 1; i++) {
			for (int j = i +1; j < arr.length; j++) {
				if (arr[i] > arr[j]) {
					//如果元素小於首元素,就進行交換
					int temp;
					temp = arr[i];
					arr[i] = arr[j];
					arr[j] = temp;
				}
			}
		}

		
		for (int i = 0; i < arr.length; i++) {
			System.out.println(arr[i]);
		}
		
	}

}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章