STL源码剖析 算法 set

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie

set相关算法

------------------------------------------------------------------------------------

描述:

set_union , set_difference , set_intersection , set_symmetric_difference 算法接受的 set ,

必须是有序区间,适用于以 RB-tree 为底层的 set/multiset , 不适用于以 hash 为底层的 hash_set/hash_multiset

当然也适用于非 set/multiset 的其它有序区间,只要有序就可以了

源码:

set_union

构造 S1 、 S2 的并集,如果某个值在 S1 出现 n 次,在 S2 出现 m 次,那么该值在输出区间中会出现 max(m, n) 次

图 6-5a

template <class InputIterator1, class InputIterator2, class OutputIterator>
OutputIterator set_union(InputIterator1 first1, InputIterator1 last1,
                         InputIterator2 first2, InputIterator2 last2,
                         OutputIterator result) {
  //当两区间都尚未到达尾端时,执行以下操作
  while (first1 != last1 && first2 != last2) {
    //两元素不等,取较小元素,并前移较小元素所在区间的迭代器
    if (*first1 < *first2) {
      *result = *first1;
      ++first1;
    }
    else if (*first2 < *first1) {
      *result = *first2;
      ++first2;
    }

	//两元素相等,取S1元素,移动两个区间的迭代器
    else {
      *result = *first1;
      ++first1;
      ++first2;
    }
	//移动结果区间的迭代器
    ++result;
  }
  //只要有一个区间到达尾端,就结束上述的 while 循环,然后将未到达尾端的
  //区间的所有元素拷贝到目的端
  return copy(first2, last2, copy(first1, last1, result));
}

set_intersection

构造 S1 、S2 的交集,如果某个值在 S1 出现 n 次,在 S2 出现 m 次,那么该值在输出区间中会出现 min(m, n) 次

图6-5b

template <class InputIterator1, class InputIterator2, class OutputIterator>
OutputIterator set_intersection(InputIterator1 first1, InputIterator1 last1,
                                InputIterator2 first2, InputIterator2 last2,
                                OutputIterator result) {
  //当两个区间都尚未到达尾端时,执行以下操作
  while (first1 != last1 && first2 != last2)
    //前移较小元素区间的迭代器直到有元素相同
    if (*first1 < *first2)
      ++first1;
    else if (*first2 < *first1)
      ++first2;
	//两区间元素值相同
    else {
      *result = *first1;
      ++first1;
      ++first2;
      ++result;
    }
  return result;
}

set_difference

构造 S1 、S2 的差集,如果某个值在 S1 出现 n 次,在 S2 出现 m 次,那么该值在输出区间中会出现 min(n-m, 0) 次

图6-5c

template <class InputIterator1, class InputIterator2, class OutputIterator>
OutputIterator set_difference(InputIterator1 first1, InputIterator1 last1,
                              InputIterator2 first2, InputIterator2 last2,
                              OutputIterator result) {
  //当两个区间都尚未到达尾端时,执行以下操作
  while (first1 != last1 && first2 != last2)
    //当S1 元素小于 S2元素,取 S1 元素
    if (*first1 < *first2) {
      *result = *first1;
      ++first1;
      ++result;
    }
	//当S1 元素大于 S2元素,前移 S2 迭代器
    else if (*first2 < *first1)
      ++first2;
	//当S1、S2 元素相等,前移 S1、S2 两个迭代器
    else {
      ++first1;
      ++first2;
    }
  //如果是 S2 先结束,还要复制 S1 剩下的元素
  return copy(first1, last1, result);
}

set_symmetric_difference --> 出现于 S1 但不出现于 S2 及 出现于 S2 但不出现于 S1

构造 S1 、S2 的对称差集,如果某个值在 S1 出现 n 次,在 S2 出现 m 次,那么该值在输出区间中会出现 |n-m| 次

图6-5d

template <class InputIterator1, class InputIterator2, class OutputIterator>
OutputIterator set_symmetric_difference(InputIterator1 first1,
                                        InputIterator1 last1,
                                        InputIterator2 first2,
                                        InputIterator2 last2,
                                        OutputIterator result) {
  //当两区间都尚未到达尾端时,执行以下操作
  while (first1 != last1 && first2 != last2)
    //当S1的元素小于S2的元素,取S1的元素
	if (*first1 < *first2) {
      *result = *first1;
      ++first1;
      ++result;
    }
	//当S2的元素小于S1的元素,取S2的元素
    else if (*first2 < *first1) {
      *result = *first2;
      ++first2;
      ++result;
    }
	//相等时,两个元素都不取
    else {
      ++first1;
      ++first2;
    }
  return copy(first2, last2, copy(first1, last1, result));
}

STL源码剖析 算法 set

时间: 2024-10-12 03:27:54

STL源码剖析 算法 set的相关文章

STL 源码剖析 算法 stl_algo.h -- search_n

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie search_n ---------------------------------------------------------------------------------------- 描述:在序列[first, last) 所涵盖的区间中,查找"连续 count 个符合条件之元素"所形成的子序列, 并返回迭代器 last 思路: 1.首先找出 value 第一次出现点

STL 源码剖析 算法 stl_algo.h -- lower_bound

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie lower_bound(应用于有序区间) -------------------------------------------------------------------------------------------------------------------------- 描述:二分查找,返回一个迭代器指向每一个"不小于 value "的元素, 或 value 应该

STL 源码剖析 算法 stl_algo.h -- upper_bound

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie upper_bound(应用于有序区间) ------------------------------------------------------------------------------------------------------------------------------------------------- 描述:受STL区间前闭后开习惯的影响,upper_boun

STL 源码剖析 算法 stl_algo.h -- binary_search

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie binary_search ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ 描

STL 源码剖析 算法 stl_algo.h -- next_permutation

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie next_permutation ----------------------------------------------------------------------- 描述: 取得 [first, last) 所标示之序列的下一个排列组合.如果没有,返回 false,有,返回true 思路: 从后往前 1.找两个相邻元素,令左端的元素为*i,右端的元素为*ii,且满足 *i <

STL 源码剖析 算法 stl_algo.h -- pre_permutation

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie pre_permutation ---------------------------------------------------------------- 描述: 取得 [first, last) 所标示之序列的前一个排列组合.如果没有,返回 false,有,返回true 思路: 从后往前 1.找两个相邻元素,令左端的元素为*i,右端的元素为*ii,且满足 *i > *ii 2.找出

STL 源码剖析 算法 stl_algo.h -- random_shuffle

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie random_shuffle -------------------------------------------------------------------------------------------------------------------------------------------------------------------------- 描述:将[first

STL 源码剖析 算法 stl_algo.h -- partial_sort / partial_sort_copy

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie partial_sort / partial_sort_copy ----------------------------------------------------------------------------------------------------------------------------------------- 描述:本算法接受一个 middle 迭代器(位于序

STL 源码剖析 算法 stl_algo.h -- equal_range

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie equal_range(应用于有序区间) -------------------------------------------------------------------------------------------------------------------------------------- 描述:利用二分查找找到一个区间,区间里的所有值都等于给定值,返回的是一个pair

STL 源码剖析 算法 stl_algo.h -- nth_element

本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie nth_element ------------------------------------------------------------------------------ 描述:重新排序,使得[nth,last)内没有任何一个元素小于[first,nth)内的元素, 但对于[first,nth)和[nth,last)两个子区间内的元素次序则无任何保证. 思路: 1.以 media