zoukankan      html  css  js  c++  java
  • 合并排序(非哨兵方法)

    //subMerge2----非哨兵方法实现两个有序序列的合并
    template<typename T>
    void subMerge2(vector<T> &array,
    typename vector<T>::iterator iterBegin,
    typename vector<T>::iterator iterBarrier,
    typename vector<T>::iterator iterEnd)
    {
    //创建两个数组,分别存放以iterBarrier为界线的array的左边部分和右边部分
    vector<T> arrayLeft(iterBegin, iterBarrier+1);
    vector<T> arrayRight(iterBarrier+1, iterEnd);

    //定义分别指向两个数组的迭代器
    typename vector<T>::iterator iterLeft = arrayLeft.begin();
    typename vector<T>::iterator iterRight = arrayRight.begin();

    //定义指向原数组array的迭代器
    typename vector<T>::iterator iterArray = iterBegin;

    //只要其中一个数组为空则跳出循环
    while(iterLeft!=arrayLeft.end() && iterRight!=arrayRight.end())
    {
    if(*iterLeft < *iterRight) //如果左边小,将左边的值放入原数组
    {
    *iterArray = *iterLeft;
    ++iterLeft;
    ++iterArray;
    }
    else //如果右边小,将右边的值放入原数组
    {
    *iterArray = *iterRight;
    ++iterRight;
    ++iterArray;
    }
    }
    //左边为空
    if(iterLeft==arrayLeft.end())
    {
    //将右边剩下的数据复制到原数组
    //array.erase(iterArray, iterEnd);
    //array.insert(iterArray, iterRight, arrayRight.end());
    while(iterRight != arrayRight.end())
    {
    *iterArray = *iterRight;
    ++iterRight;
    ++iterArray;
    }
    }
    //右边为空
    if(iterRight==arrayRight.end())
    {
    //将左边剩下数据复制到原数组
    //array.erase(iterArray, iterEnd);
    //array.insert(iterArray, iterLeft, arrayLeft.end());
    while(iterLeft != arrayLeft.end())
    {
    *iterArray = *iterLeft;
    ++iterLeft;
    ++iterArray;
    }
    }
    return;
    }

    用此函数代替之前mergeSort()中的 subMerge即可。其中在将左边或右边剩余元素复制到原数组的时候,如果用 vector成员函数insert,

    必须先将iterArray所指位置右边的元素删除,不然会使iterArray右边的元素向后移动,导致元素个数增多。

  • 相关阅读:
    Medium | LeetCode 148. 排序链表 | 归并排序(递归)
    Hard | LeetCode 4. 寻找两个正序数组的中位数 | 二分法
    Medium | LeetCode 341. 扁平化嵌套列表迭代器 | 递归 | 栈
    Hard | LeetCode 312. 戳气球 | 递归+记忆化数组 | 动态规划
    如何删除万能输入法
    javaweb 怎么获取路径
    Controller 返回 json那些小事
    螺旋矩阵
    javaweb怎么使用html
    tomcat中文乱码
  • 原文地址:https://www.cnblogs.com/haigege/p/2299302.html
Copyright © 2011-2022 走看看