std::set_difference
来自cppreference.com
                    
                                        
                    
                    
                                                            
                    |  | 该页由英文版wiki使用Google Translate机器翻译而来。 
 该翻译可能存在错误或用词不当。鼠标停留在文本上可以看到原版本。你可以帮助我们修正错误或改进翻译。参见说明请点击这里. | 
| 定义于头文件  <algorithm> | ||
| template< class InputIt1, class InputIt2, class OutputIt > OutputIt set_difference( InputIt1 first1, InputIt1 last1, | (1) | |
| template< class InputIt1, class InputIt2,           class OutputIt, class Compare > | (2) | |
副本中的元素排序的范围
[first1, last1)都没有发现在已排序的范围内,[first2, last2)在d_first的范围开始 原文:
Copies the elements from the sorted range 
[first1, last1) which are not found in the sorted range [first2, last2) to the range beginning at d_first. 由此获得的范围也进行排序。的第一个版本预计两个输入范围与operator<,第二个版本需要进行排序的比较函数
comp进行排序。等效元素单独处理,即,如果发现一些元件m次[first1, last1)n在[first2, last2)的时候,它将被复制到d_first完全相同std::max(m-n, 0)倍,由此获得的范围不能与任一输入范围重叠.原文:
The resulting range is also sorted. The first version expects both input ranges to be sorted with operator<, the second version expects them to be sorted with the given comparison function 
comp. Equivalent elements are treated individually, that is, if some element is found m times in [first1, last1) and n times in [first2, last2), it will be copied to d_first exactly std::max(m-n, 0) times. The resulting range cannot overlap with either of the input ranges.| 目录 | 
[编辑] 参数
| first1, last1 | - |  检查的元素 | 
| first2, last2 | - |  的元素的范围搜索 | 
| comp | - | 比较函数对象(即满足比较( Compare)要求的对象),若首个参数小于第二个,则返回 true 。比较函数的签名应等价于如下者: bool cmp(const Type1 &a, const Type2 &b); 签名不需要拥有 const & ,但函数对象必须不修改传递给它的对象。 | 
| 类型要求 | ||
| - InputIt1必须满足 InputIterator的要求。 | ||
| - InputIt2必须满足 InputIterator的要求。 | ||
| - OutputIt必须满足 OutputIterator的要求。 | ||
[编辑] 返回值
过去的结尾的Iterator构建范围.
原文:
Iterator past the end of the constructed range.
[编辑] 复杂度
最2·(N1+N2-1)比较,其中N1= std::distance(first1, last1)和N2= std::distance(first2, last2).
原文:
At most 2·(N1+N2-1) comparisons, where N1 = std::distance(first1, last1) and N2 = std::distance(first2, last2).
[编辑] 可能的实现
| 版本一 | 
|---|
| template<class InputIt1, class InputIt2, class OutputIt> OutputIt set_difference(InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2, OutputIt d_first) { while (first1 != last1) { if (first2 == last2) return std::copy(first1, last1, d_first); if (*first1 < *first2) { *d_first++ = *first1++; } else { if (! (*first2 < *first1)) { ++first1; } ++first2; } } return d_first; } | 
| 版本二 | 
| template<class InputIt1, class InputIt2, class OutputIt, class Compare> OutputIt set_difference( InputIt1 first1, InputIt1 last1, InputIt2 first2, InputIt2 last2, OutputIt d_first, Compare comp) { while (first1 != last1) { if (first2 == last2) return std::copy(first1, last1, d_first); if (comp(*first1, *first2)) { *d_first++ = *first1++; } else { if (!comp(*first2, *first1)) { ++first1; } ++first2; } } return d_first; } | 
[编辑] 示例
#include <iostream> #include <algorithm> #include <vector> #include <iterator> int main() { std::vector<int> v1 {1, 2, 5, 5, 5, 9}; std::vector<int> v2 {2, 5, 7}; std::vector<int> diff; std::set_difference(v1.begin(), v1.end(), v2.begin(), v2.end(), std::inserter(diff, diff.begin())); for (auto i : v1) std::cout << i << ' '; std::cout << "minus "; for (auto i : v2) std::cout << i << ' '; std::cout << "is: "; for (auto i : diff) std::cout << i << ' '; std::cout << '\n'; }
输出:
1 2 5 5 5 9 minus 2 5 7 is: 1 5 5 9
[编辑] 另请参阅
| 如果一个集合是另外一个集合的子集则返回true (函数模板) | |
| 计算两个集合的对称差 (函数模板) | 


