排序演算法(一)

2022-09-07 21:21:15 字數 606 閱讀 7270

執行時間與輸入無關。都為\(\fracn^2\)

資料移動最小,與陣列大小 n 成正比。

選擇的含義體現在每次內迴圈都選出了最小的元素。

public class selection

}exch(a,i,min);}}

//判斷前者是否小於後者

private static boolean less(comparable a,comparable b)

//兩者交換

private static void exch(comparable a,int i,int j)

//判斷是否有序(自然序)

private static boolean issort(comparable a)

}return true;

}//對外提供展示方法

public static void show(comparable a)

}public static void main(string args) ;

sort(a);

system.out.println(issort(a));

show(a);

}}

排序演算法(一)

這個學期課程很少,空閒時間很多,故重新複習了一下 演算法導論 中的常用演算法和資料結構,並且將實現 儲存到部落格,以便大三暑假找實習時方便複習。直接插入排序的思想非常簡單,將序列中第乙個元素作為乙個有序序列,然後將剩下的n 1個元素按關鍵字大小依此插入該有序序列,每插入乙個元素後依然保持該序列有序,...

排序演算法一

3個簡單的排序演算法,不多解釋了,直接上 include include void display int a,int n printf n void exchange int a,int i,int j 氣泡排序 void popsort int a,int n end for j printf ...

排序演算法(一)

氣泡排序 基本思想 在要排序的一組數中,對當前還未排好序的範圍內的全部數,自上而下對相鄰的兩個數依次進行比較和調整,讓較大的數往下沉 較小的往上冒。即 每當兩相鄰的數比較後發現它們的排序與排序要求相反時,就將它們互換。氣泡排序的示例 演算法實現 void print int arr,int size...