c – 如何检查一个矢量是否是另一个矢量的子集?

目前,我认为我最好的选择是使用std :: set_intersection,然后检查较小输入的大小是否与set_intersection填充的元素数量相同.

有更好的解决方案吗?

解决方法

尝试这个:
if (std::includes(set_one.begin(),set_one.end(),set_two.begin(),set_two.end()))
{
// ...
}

includes().

The includes() algorithm compares two
sorted sequences and returns true if
every element in the range [start2,
finish2) is contained in the range
[start1,finish1). It returns false
otherwise. includes() assumes that the
sequences are sorted using
operator<(),or using the predicate
comp.

跑进来

At most ((finish1 – start1) + (finish2
– start2)) * 2 – 1 comparisons are performed.

Plus O(nlog(n))用于排序向量.你不会比它快得多.

相关文章

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