选择排序与插入排序类似都是1空间复杂度并且时间复杂度位N平方的排序算法(插入算法在最差情况时才是N平方),他们在处理小规模的数据时效率不错。
选择排序的思路就是,不断的找出最小或者最大的元素放在他所应该存在的位置(index)。保证在index前的元素都是有序的并不断增加index的位置
数学归纳法来看:
1.当仅有一个元素时,他就是最小的
2.不断的对index后的全部元素进行遍历找出最小或者最大的与index位置的元素交换位置,这样保证了每一次循环前0到index-1的元素都是有序的。
3.在index到了最后一个元素时结束
代码如下:
public static void sort(int[] ints){
int index = 0;
while (index<ints.length){
int min = ints[index];
int save = index;
for (int i =index;i<ints.length;i++){
if (ints[i]<min){
min = ints[i];
save = i;
}
}
ints[save] = ints[index];
ints[index] = min;
index++;
}
}