SelectSort
代碼
package Sort;/** * @author Biang Hoo *O(n ^2 ) * 2013年9月10日 */public class SelectSort implements Sort{@Overridepublic void Sorting(int[] array) {int min;int tmp;for(int i=0;i<array.length;i++){min=i;for(int j=i+1;j<array.length;j++){if(array[j]<array[min]){min =j;}}tmp =array[i];array[i] =array[min];array[min]=tmp;}}}
HeapSort
代碼
package Sort;import java.util.Arrays;/** * @author Biang Hoo * * 2013年9月14日 */public class HeapSort implements Sort {public void Sorting(int[] array) {MakeMinHeap(array);for(int i=array.length-1;i>0;i--){Swap(array,0,i);ShiftDown(array,0,i-1);}}private void MakeMinHeap(int[] array){int len = array.length;for(int i=len/2-1;i>=0;i--){ShiftDown(array,i,len);}}private void ShiftDown(int[] array,int i,int n){int temp = array[i];int key=2*i+1;while(key<n ){if(key+1<n && array[key]>array[key+1]){key++;}if(array[key]>temp){break;}array[i] =array[key];i = key;key = 2*i+1;}array[i] = temp;}private void Swap(int[] array,int i,int j){int temp = array[i];array[i] = array[j];array[j] = temp;}}