是否可以根据另一个向量的信息从一个向量中删除某些元素
Is it possible to remove certain elements from a vector based on the information from another vector?
假设我们有向量A和B包含的对象不是基元数据。
B向量将包含关于哪些元素的信息从向量A中删除。如果可能的话,我不想依赖索引。
我怀疑在Java中,这可以通过方法调用来完成to remove所有传递要删除的内容列表的位置作为参数删除。
这在C++语言中可能吗?
谢谢!
如果对向量进行排序,则可以使用std::set_difference
。事实上,如果你不先对它们进行排序,那么在复杂性方面,你不会比n^2更好。所以我的建议是:对向量进行排序并使用set_difference。
在不知道A
和B
包含的具体内容的情况下,可以执行以下操作:
std::vector<int> A;
std::vector<int> B;
// fill in your vectors
A.erase(std::remove_if(A.begin(), A.end(), [&](int i)
{
return std::find(B.begin(), B.end(), i) != B.end();
}), A.end());
这将在B
中搜索与A
中匹配的任何内容。如果发现什么东西,它将被移除。
这个过程可以分解为:
1) 选择符合要删除元素条件的比较方法,
2) 找到删除选定元素的方法(作为连续范围或逐个删除)。
为什么这会成为一个问题?你只需要找到一种方法来比较向量B上的元素和向量a上的元素,并在此基础上,构建一个要删除的元素列表,然后删除它们。
当然,你的向量可以是某个类的向量,它包含了在a和B中的对象之间进行比较所需的所有属性。
相关文章:
- 函数向量_指针有不同的原型,我可以构建一个吗
- C++从另一个类访问公共静态向量的正确方法是什么
- 为什么我不能将一个对象push_back到属于另一个类的对象向量中?
- 给定一个向量,如何找到该向量的所有子集和的原始索引
- 获取向量C++中第一个值和最后一个值的和
- 从多个源构造一个对象,包括一个对象向量
- 为什么一个向量上的多线程操作很慢
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- C++ - 如何在结构向量中找到结构体一个成员的最大值?
- 如何在 C++11 中查找和更新向量中的一个嵌套结构
- Lower_bound不适用于具有 3 个元素的向量的最后一个元素
- 将一个向量插入另一个向量的某个位置
- std::find,返回所有找到的值的替代方法,而不仅仅是存在重复的向量的第一个值
- 将指向给定子类的指针从一个向量复制到另一个向量
- 如何创建一个类,以便向量工作 std::vector<MyClass<int>> v{ 1,2,3 };
- C++ STD 函数运算符:有没有一种方法可以通过函数将一个向量映射到另一个向量上?
- 将向量之间的数字放在另一个向量之间<vector>>如果两个数字的差值为 1
- 如何在不复制的情况下将一个向量移动到另一个向量中
- 创建一个函数的 Python 绑定,返回指向带有 boost 的向量的指针
- 紧凑向量一个小的内存足迹向量