使用纯C++迭代器编写归并排序

Posted yuanyb

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用纯C++迭代器编写归并排序相关的知识,希望对你有一定的参考价值。

第一次尝试用C++迭代器编写算法,使用的是纯迭代器

void mergeSort(vector<int>::iterator beg, vector<int>::iterator end) //排序区间 [beg, end)
    if(end - beg < 2)
        return;
    auto mid = beg + (end - beg) / 2;
    mergeSort(beg, mid);
    mergeSort(mid, end);
    //=== merge_beg ===
    vector<int> A(beg, mid); //复制前子向量,因为构造有序向量要占用前子向量
    auto iter_a = A.begin(), iter_b = mid; //分别指向前后子向量起始位置的迭代器
    auto iter_c = beg; //指向有序向量的起始位置
    while(iter_a < A.end() || iter_b < end)
        if(iter_b >= end || (iter_a < A.end() && *iter_a < *iter_b))
            *iter_c++ = *iter_a++;
        if(iter_a >= A.end() || (iter_b < end && *iter_a >= *iter_b))
            *iter_c++ = *iter_b++;
    
    //=== merge_end ===

  

以上是关于使用纯C++迭代器编写归并排序的主要内容,如果未能解决你的问题,请参考以下文章

c++链表归并排序的迭代版本

归并排序

排序算法之归并排序迭代实现

大话数据结构C语言69 归并排序(递归和迭代实现)

排序算法的c++实现——归并排序

动画 | 什么是归并排序?