zoukankan      html  css  js  c++  java
  • 使用纯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 ===
    }
    

      

  • 相关阅读:
    uIP的ARP协议分析
    如何使函数不生成执行代码
    计算机网络基础
    [Hive
    [Hive
    [Hive
    [Hive
    [Hive
    [Hive
    [Hive
  • 原文地址:https://www.cnblogs.com/yuanyb/p/11291613.html
Copyright © 2011-2022 走看看