选择排序

在i~n-1范围内,找到最小值并放在i的位置上, 然后在i+1 ~ n-1范围内继续

for(int i = 0; i < n - 1; i++){
    int min = i;
    for (int j = i + 1; j < n; j++){
        if (arr[j] < arr[min]){
			min = j;
		}
    }
	swap(arr[i], arr[j]);
}

冒泡排序

在0~i范围内, 相邻位置较大的数向下滚动, 最大值最终来到i的位置,然后0 ~ i-1范围继续

for(int end = n - 1; end > 0; end--){
    for(int i = 0; i < end; i++){
        if (arr[i] > arr[i+1]){
			swap(arr[i], arr[i+1]);
        }
    }
}

插入排序

0~i范围内已经有序, 新来的数从右往左滑倒不再小的位置插入,然后继续

for(int i = 1; i < n; i++){
    for(int j = i; j > 0 && arr[j] < arr [j-1]; j--){
        swap(arr[j], arr[j-1]);
    }
}