演算法描述 1.假定未排序序列中第一位為數組最小值,通過與後面的數值進行比較,找到未排序序列中最小值,與未排序序列第一位交換位置; 2.重覆步驟一,對剩餘未排序序列進行比較找出最小值,與未排序序列中第一位數值交換位置,直到數組所有數值排序完成; 代碼實現 完整代碼 ...
演算法描述
1.假定未排序序列中第一位為數組最小值,通過與後面的數值進行比較,找到未排序序列中最小值,與未排序序列第一位交換位置;
2.重覆步驟一,對剩餘未排序序列進行比較找出最小值,與未排序序列中第一位數值交換位置,直到數組所有數值排序完成;
代碼實現
/* 例如:對數組:{ 2,7,6,3,1 }進行比較 第一輪:{ 1,7,6,3,2 } :共比較四次 第二輪:{ 1,2,6,3,7 } :共比較三次 第三輪:{ 1,2,3,6,7 } :共比較二次 第四輪:{ 1,2,3,6,7 } :共比較一次 */ public void Select(int[] arr) { int temp; int number; int numIndex; bool flag; for (int i = 0; i < arr.Length -1; i++) { flag = true; number = arr[i]; numIndex = i; for (int j = i + 1; j < arr.Length; j++) { if (number > arr[j]) { number = arr[j]; numIndex = j; flag = false; } } temp = arr[i]; arr[i] = arr[numIndex]; arr[numIndex] = temp; if (flag == true) { break; } Console.Write("選擇排序:"); foreach (int item in arr) { Console.Write(item + " "); } Console.WriteLine(); } }
完整代碼
using System; namespace SelectSortApplication { class Program { static void Main(string[] args) { var setArray = new SetArray(); var selectSort = new SelectSort(); int[] arr = setArray.GetArray(); selectSort.Select(arr); Console.ReadLine(); } } class SetArray { public int[] GetArray() { int length; int[] arr; Console.WriteLine("請輸入數組長度:"); length = Convert.ToInt32(Console.ReadLine()); arr = new int[length]; for (int i = 0; i <= length -1; i++) { Console.Write("請輸入數組第{0}位數值:", i); arr[i] = Convert.ToInt32(Console.ReadLine()); } Console.Clear(); Console.Write("arr[] = {"); foreach (int item in arr) { Console.Write(item + " "); } Console.Write("}\n"); return arr; } } class SelectSort { public void Select(int[] arr) { int temp; int number; int numIndex; bool flag; for (int i = 0; i < arr.Length -1; i++) { flag = true; number = arr[i]; numIndex = i; for (int j = i + 1; j < arr.Length; j++) { if (number > arr[j]) { number = arr[j]; numIndex = j; flag = false; } } temp = arr[i]; arr[i] = arr[numIndex]; arr[numIndex] = temp; if (flag == true) { break; } } Console.Write("選擇排序:"); foreach (int item in arr) { Console.Write(item + " "); } Console.WriteLine(); } } }