C:从容器1中找到任何元素,而不是在容器2中

我有一个std :: set< int> (s)和std :: vector< int> (五).向量保证被排序/唯一.我想知道v的所有元素是否在s中(或者只是停止在v的第一个元素不在s中).我可以将v转换成一个集合并做==测试,但是有没有另外一种方式而不改变容器类型?

解决方法

std::includes算法是什么?

以下是一个简短的用法示例:

vector<int> v1 { 1,2,4,8 };
vector<int> v2 { 1,3,8 };
set<int> s { 0,1,8,16 };
cout << includes(s.begin(),s.end(),v1.begin(),v1.end()) << endl;
cout << includes(s.begin(),v2.begin(),v2.end()) << endl;

输出:

1
0

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...