两个字符集C ++的集合差异

div*_*nan 4 c++ stl set

问题

我有两个排序集:

set<char, greater<char> > alp1;
set<char, greater<char> > alp;
Run Code Online (Sandbox Code Playgroud)

我需要找到设置差异:alp-alp1

尝试1

set_difference(alp.begin(), alp.end(), alp1.begin(), alp1.end(), inserter(diff1, diff1.end()));
Run Code Online (Sandbox Code Playgroud)

但是,仅从alp1中减去的第一个元素alp

尝试2

itr = set_difference(alp.begin(), alp.end(), alp1.begin(), alp1.end(), diff1.begin());
for(auto it=diff.begin(); it<itr; it++)
   cout<<*it;
Run Code Online (Sandbox Code Playgroud)

尝试2错误:

no match for ‘operator<’ (operand types are ‘std::_Rb_tree_const_iterator<char>’ and ‘std::set<char>::const_iterator’ {aka ‘std::_Rb_tree_const_iterator<char>’})
Run Code Online (Sandbox Code Playgroud)

我该如何解决这个问题?

Yan*_*ang 6

您需要将一个greater<char>()比较器传递给set_difference,用于您的集合的相同比较器(请参阅完整的API):

#include <algorithm>
#include <iostream>
#include <set>

using namespace std;

int main() {
  set<char, greater<char>> alp = {'a', 'b', 'c', 'd', 'e'};
  set<char, greater<char>> alp1 = {'a', 'b', 'c'};
  set<char, greater<char>> diff;
  set_difference(alp.begin(), alp.end(), alp1.begin(), alp1.end(),
                 inserter(diff, diff.begin()), greater<char>());
  for (const char c : diff) {
    cout << c;
  }
  return 0;
}
Run Code Online (Sandbox Code Playgroud)

输出:

ed
Run Code Online (Sandbox Code Playgroud)

演示:http : //cpp.sh/3be2u