数据结构——排序算法——插入排序

交换法插入排序

void swap(vector<int> arr, int i, int j)
{
    int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;

}

void insertSort(vector<int> arr)
{
    // 从第二个数开始,往前插入数字
    for (int i = 1; i < arr.size(); i++) {
        // j 记录当前数字下标
        int j = i;
        // 当前数字比前一个数字小,则将当前数字与前一个数字交换
        while (j >= 1 && arr[j] < arr[j - 1]) {
            swap(arr, j, j - 1);
            // 更新当前数字下标
            j--;
        }
    }
}

移动法插入排序

void insertSort2(vector<int> arr)
{
    // 从第二个数开始,往前插入数字
    for (int i = 1; i < arr.size(); i++) {
        int currentNumber = arr[i];
        int j = i - 1;
        // 寻找插入位置的过程中,不断地将比 currentNumber 大的数字向后挪
        while (j >= 0 && currentNumber < arr[j]) {
            arr[j + 1] = arr[j];
            j--;
        }
        // 两种情况会跳出循环:1. 遇到一个小于或等于 currentNumber 的数字,跳出循环,currentNumber 就坐到它后面。
        // 2. 已经走到数列头部,仍然没有遇到小于或等于 currentNumber 的数字,也会跳出循环,此时 j 等于 -1,currentNumber 就坐到数列头部。
        arr[j + 1] = currentNumber;
    }
}

数据结构——排序算法——插入排序_第1张图片

你可能感兴趣的:(排序算法,排序算法,数据结构,算法)