anybody can use these code. It's free.
class SortAlgorithm { public void BubbleSort(int[] R) { int i, j, temp; bool exchange; for (i = 0; i < R.Length; i++) { exchange = false; for (j = 0; j < R.Length - 1; j++) { if (R[j + 1] < R[j]) { temp = R[j + 1]; R[j + 1] = R[j]; R[j] = temp; exchange = true; } } if (!exchange) { break; } } PrintList(R); } public void SelectionSort(int[] list) { int min; for (int i = 0; i < list.Length - 1; i++) { min = i; for (int j = i + 1; j < list.Length; j++) { if (list[j] < list[min]) min = j; } int t = list[min]; list[min] = list[i]; list[i] = t; } PrintList(list); } public void InsertSort(int[] arr) { for (int i = 1; i < arr.Length; i++)//从第二个元素开始 { //1, 5, 3, 6, 10, 55, 9 int temp = arr[i]; int j = i - 1; while (arr[j] > temp)//从从当前元素往右边找插入点 { arr[j + 1] = arr[j];//后移 j--; if (j == -1) break; } arr[j + 1] = temp;//前面已经后移了,会留下一个空位置,现在就插入 PrintList(arr); } } public void PrintList(int[] R) { foreach (int r in R) { Console.WriteLine("value is:{0}", r); } } static void Main(string[] args) { SortAlgorithm sa = new SortAlgorithm(); int[] list = new int[] { 1, 5, 3, 6, 10, 55, 9 }; sa.BubbleSort(list); sa.SelectionSort(list); sa.InsertSort(list); Console.Read(); } }

  

posted on 2013-01-15 10:47  ilawrence  阅读(730)  评论(0编辑  收藏  举报