基础算法(二)| 归并排序

分治思想

确定中间为分界点

mid = (l+r)>>1

递归排序左右两端

归并,合二为一

在这里插入图片描述
双指针法,比较当前所指数大小,小的填入临时数组,相应的指针前进

在这里插入图片描述

模板

void merge_sort(int q[], int l, int r) {
	int temp[10000];
    if (l >= r) return;

    int mid = l + r >> 1;

    merge_sort(q, l, mid), merge_sort(q, mid + 1, r);

    int k = 0, i = l, j = mid + 1;


    while (i <= mid && j <= r) {
        if (q[i] < q[j]) temp[k++] = q[i++];
        else temp[k++] = q[j++];
    }

    while (i <= mid) temp[k++] = q[i++];
    while (j <= r) temp[k++] = q[j++];

    for (i = l, j = 0; i <= r; i++, j++) q[i] = temp[j];

}

版权声明:本文为ngtnmd原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。