std::merge
来自cppreference.com
                    
                                        
                    
                    
                                                            
                    |  | 该页由英文版wiki使用Google Translate机器翻译而来。 
 该翻译可能存在错误或用词不当。鼠标停留在文本上可以看到原版本。你可以帮助我们修正错误或改进翻译。参见说明请点击这里. | 
| 定义于头文件  <algorithm> | ||
| template< class InputIt1, class InputIt2, class OutputIt > OutputIt merge( InputIt1 first1, InputIt1 last1, | (1) | |
| template< class InputIt1, class InputIt2, class OutputIt, class Compare> OutputIt merge( InputIt1 first1, InputIt1 last1, | (2) | |
合并两个已排序的范围
[first1, last1),[first2, last2)成一个有序区间开始在d_first。 operator<的第一个版本使用比较的元素,第二个版本使用给定的比较函数comp。等效的元件的相对顺序被保留.原文:
Merges two sorted ranges 
[first1, last1) and [first2, last2) into one sorted range beginning at d_first. The first version uses operator< to compare the elements, the second version uses the given comparison function comp. The relative order of equivalent elements is preserved.| 目录 | 
[编辑] 参数
| first1, last1 | - |  第一个范围的元素进行合并 原文:  the first range of elements to merge | 
| first2, last2 | - |  要合并的元素的第二范围 原文:  the second range of elements to merge | 
| d_first | - |  的目标范围的开头 原文:  the beginning of the destination range | 
| comp | - | 比较函数对象(即满足比较( Compare)要求的对象),若首个参数小于第二个,则返回 true 。比较函数的签名应等价于如下者: bool cmp(const Type1 &a, const Type2 &b); 签名不需要拥有 const & ,但函数对象必须不修改传递给它的对象。 | 
| 类型要求 | ||
| - InputIt1必须满足 InputIterator的要求。 | ||
| - InputIt2必须满足 InputIterator的要求。 | ||
| - OutputIt必须满足 OutputIterator的要求。 | ||
[编辑] 返回值
复制过去的最后一个元素的输出迭代器的元素.
原文:
An output iterator to element past the last element copied.
[编辑] 复杂度
在大多数std::distance(first1, last1) + std::distance(first2, last2) + 1比较.
原文:
At most std::distance(first1, last1) + std::distance(first2, last2) + 1 comparisons.
[编辑] 可能的实现
| 版本一 | 
|---|
| template<class InputIt1, class InputIt2, class OutputIt> OutputIt merge(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2, OutputIt d_first) { for (; first1 != last1; ++d_first) { if (first2 == last2) { return std::copy(first1, last1, d_first); } if (*first2 < *first1) { *d_first = *first2; ++first2; } else { *d_first = *first1; ++first1; } } return std::copy(first2, last2, d_first); } | 
| 版本二 | 
| template<class InputIt1, class InputIt2, class OutputIt, class Compare> OutputIt merge(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2, OutputIt d_first, Compare comp) { for (; first1 != last1; ++d_first) { if (first2 == last2) { return std::copy(first1, last1, d_first); } if (comp(*first2, *first1)) { *d_first = *first2; ++first2; } else { *d_first = *first1; ++first1; } } return std::copy(first2, last2, d_first); } | 
[编辑] 示例
#include <iostream> #include <iterator> #include <cstdlib> #include <algorithm> #include <vector> int main() { const std::size_t items = 10; std::vector<int> v1, v2, dst; // fill the vectors for (std::size_t idx = 0; idx < items; ++idx) { v1.push_back(std::rand()%items); v2.push_back(std::rand()%items); } // sort std::sort(v1.begin(), v1.end()); std::sort(v2.begin(), v2.end()); // output v1 std::cout << "v1 : "; std::copy(v1.begin(), v1.end(), std::ostream_iterator<int>(std::cout, " ")); std::cout << '\n'; // output v2 std::cout << "v2 : "; std::copy(v2.begin(), v2.end(), std::ostream_iterator<int>(std::cout, " ")); std::cout << '\n'; // merge std::merge(v1.begin(), v1.end(), v2.begin(), v2.end(), std::back_inserter(dst)); // output std::cout << "dst: "; std::copy(dst.begin(), dst.end(), std::ostream_iterator<int>(std::cout, " ")); std::cout << '\n'; }
输出:
v1 : 0 0 2 2 3 3 3 6 7 9 v2 : 1 2 5 5 6 6 6 6 7 9 dst: 0 0 1 2 2 2 3 3 3 5 5 6 6 6 6 6 7 7 9 9
[编辑] 另请参阅
| 就地合并两个有序的区间 (函数模板) | |
| 将区间按升序排序 (函数模板) | |
| 将区间内的元素排序,同时保持相等的元素之间的顺序 (函数模板) | 


