Template Function thrust::set_symmetric_difference_by_key(InputIterator1, InputIterator1, InputIterator2, InputIterator2, InputIterator3, InputIterator4, OutputIterator1, OutputIterator2)¶
Function Documentation¶
-
template<typename
InputIterator1, typenameInputIterator2, typenameInputIterator3, typenameInputIterator4, typenameOutputIterator1, typenameOutputIterator2>
thrust::pair<OutputIterator1, OutputIterator2>thrust::set_symmetric_difference_by_key(InputIterator1 keys_first1, InputIterator1 keys_last1, InputIterator2 keys_first2, InputIterator2 keys_last2, InputIterator3 values_first1, InputIterator4 values_first2, OutputIterator1 keys_result, OutputIterator2 values_result) set_symmetric_difference_by_keyperforms a key-value symmetric difference operation from set theory.set_difference_by_keyconstructs a sorted range that is the symmetric difference of the sorted ranges[keys_first1, keys_last1)and[keys_first2, keys_last2). Associated with each element from the input and output key ranges is a value element. The associated input value ranges need not be sorted.In the simplest case,
set_symmetric_difference_by_keyperforms a set theoretic calculation: it constructs the union of the two sets A - B and B - A, where A and B are the two input ranges. That is, the output range contains a copy of every element that is contained in[keys_first1, keys_last1)but not[keys_first2, keys_last1), and a copy of every element that is contained in[keys_first2, keys_last2)but not[keys_first1, keys_last1). The general case is more complicated, because the input ranges may contain duplicate elements. The generalization is that if[keys_first1, keys_last1)containsmelements that are equivalent to each other and[keys_first2, keys_last1)containsnelements that are equivalent to them, then|m - n|of those elements shall be copied to the output range: the lastm - nelements from[keys_first1, keys_last1)ifm > n, and the lastn - mof these elements from[keys_first2, keys_last2)ifm < n.Each time a key element is copied from
[keys_first1, keys_last1)or[keys_first2, keys_last2)is copied to the keys output range, the corresponding value element is copied from the corresponding values input range (beginning atvalues_first1orvalues_first2) to the values output range.This version of
set_symmetric_difference_by_keycompares key elements usingoperator<.The following code snippet demonstrates how to use
set_symmetric_difference_by_keyto compute the symmetric difference of two sets of integers sorted in ascending order with their values.- Return
A
pairpsuch thatp.firstis the end of the output range of keys, and such thatp.secondis the end of the output range of values.- Pre
The ranges
[keys_first1, keys_last1)and[keys_first2, keys_last2)shall be sorted with respect tooperator<.- Pre
The resulting ranges shall not overlap with any input range.
- Parameters
keys_first1: The beginning of the first input range of keys.keys_last1: The end of the first input range of keys.keys_first2: The beginning of the second input range of keys.keys_last2: The end of the second input range of keys.values_first1: The beginning of the first input range of values.values_first2: The beginning of the first input range of values.keys_result: The beginning of the output range of keys.values_result: The beginning of the output range of values.
- Template Parameters
InputIterator1: is a model of Input Iterator,InputIterator1andInputIterator2have the samevalue_type,InputIterator1'svalue_typeis a model of LessThan Comparable, the ordering onInputIterator1'svalue_typeis a strict weak ordering, as defined in the LessThan Comparable requirements, andInputIterator1'svalue_typeis convertable to a type inOutputIterator'sset ofvalue_types.InputIterator2: is a model of Input Iterator,InputIterator2andInputIterator1have the samevalue_type,InputIterator2'svalue_typeis a model of LessThan Comparable, the ordering onInputIterator2'svalue_typeis a strict weak ordering, as defined in the LessThan Comparable requirements, andInputIterator2'svalue_typeis convertable to a type inOutputIterator'sset ofvalue_types.InputIterator3: is a model of Input Iterator, andInputIterator3'svalue_typeis convertible to a type inOutputIterator2'sset ofvalue_types.InputIterator4: is a model of Input Iterator, andInputIterator4'svalue_typeis convertible to a type inOutputIterator2'sset ofvalue_types.OutputIterator1: is a model of Output Iterator.OutputIterator2: is a model of Output Iterator.
#include <thrust/set_operations.h> ... int A_keys[6] = {0, 1, 2, 2, 4, 6, 7}; int A_vals[6] = {0, 0, 0, 0, 0, 0, 0}; int B_keys[5] = {1, 1, 2, 5, 8}; int B_vals[5] = {1, 1, 1, 1, 1}; int keys_result[6]; int vals_result[6]; thrust::pair<int*,int*> end = thrust::set_symmetric_difference_by_key(A_keys, A_keys + 6, B_keys, B_keys + 5, A_vals, B_vals, keys_result, vals_result); // keys_result is now {0, 4, 5, 6, 7, 8} // vals_result is now {0, 0, 1, 0, 0, 1}
- See
set_union_by_key- See
set_intersection_by_key- See
set_difference_by_key- See
sort_by_key- See
is_sorted