我如何适应擦除式习惯与矢量元组一起工作

How can I adapt the erase-remove idiom to work with vector tuples?

本文关键字:元组 一起 工作 习惯 何适应 擦除      更新时间:2023-10-16

我有一个带有j,k和l成员的元素向量。我正在尝试调整擦除示例的成语,以便如果.k成员的值符合一定条件,则可以删除整个元组。

我尝试使用标准.erase(Remove F(((方法,其中谓词引用了元组成员的位置,但被告知所讨论的矢量类别没有成员" k"。

vec_list_iter_exp_out.erase(
    std::remove_if(
        vec_list_iter_exp_out.begin(),
        vec_list_iter_exp_out.end(), 
        vec_list_iter_exp_out.k < 33), vec_list_iter_exp_out.end());

我希望,如果Vec_list_iter_exp_out由以下,假设值组成:

vec_list_iter_exp_out[0] = 5, 22, 9
vec_list_iter_exp_out[1] = 12, 31, 54
vec_list_iter_exp_out[2] = 17, 42, 0
vec_list_iter_exp_out[3] = 253, 3, 5
vec_list_iter_exp_out[4] = 65, 110, 24

vec_list_iter_exp_out [2]和vec_list_iter_exp_out [4]的整体将被删除,vec_list_iter_exp_out将包含以下内容:

vec_list_iter_exp_out[0] = 5, 22, 9
vec_list_iter_exp_out[1] = 12, 31, 54
vec_list_iter_exp_out[2] = 253, 3, 5

相反,我得到了上述编译错误。

任何帮助将不胜感激!

编辑:根据要求的向量的定义。

struct TriStore
{
    double j,k,l;
};
std::vector<TriStore> vec_list_iter_exp_out;

和用于插入的摘要(显然引用了其他功能和什么功能,但这会占用太多空间(

    for(int z = 1; z <= iters; z++)
    {
        vec_iters.push_back(vec_list_iter_exp_out.size());
        for(int i = vec_iters[z-1]; i < vec_iters[z]; i++)
        {
            if(vec_list_iter_exp_out[i].k < kk)
            {
                triangle_list(vec_list_iter_exp_out[i].j,vec_list_iter_exp_out[i].k,vec_list_iter_exp_out[i].l);
                vec_list_iter_exp_out.insert(vec_list_iter_exp_out.end(),vec_tri_list.begin(),vec_tri_list.end());
            }
        }
    }

remove_if的第三个参数需要是一个谓词。相反,您正在传递一个表达式。

而不是vec_list_iter_exp_out.k < 33尝试类似[](const TriStore &x){return x.k < 33;}

之类的东西

如果我想在运行时决定此33

来自Nishant Singh的这一评论:请使用

[&value](const TriStore& x) {return x.k < value;}  // Capture by reference
[value](const TriStore& x) {return x.k < value;}  // Capture by value

P.S。而不是TriStore,为什么不使用tuple<double, double, double>