使用纯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 ===
}

  

转载于:https://www.cnblogs.com/yuanyb/p/11291613.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值