小编Noo*_*oob的帖子

c ++ set_union迭代器

我对这段代码有一些问题,代码正在编译,但是当我尝试测试向量的内容时,测试失败了.这是代码:

using std::vector;

// returns a different vector, containing all elements in v1 and all elements in v2                          (elements who are either in v1 or v2) but no duplicates.

template <typename T> vector<T> set_union(const vector<T>& v1, const vector<T>&v2)
{
    vector<T> v(20);
    typename vector<T>::iterator it;

    it = set_union (v1.begin(), v1.end(), v2.begin(), v2.end(), v.begin());
    return v;
}
Run Code Online (Sandbox Code Playgroud)

这是我正在运行的测试:

TEST_F(MyTest,set_union) {
        vector<int> v1{1,3,2};
        vector<int> v2{1,4};
        vector<int> v=set_union(v1,v2);
        ASSERT_EQ(0,count(v,9));
        ASSERT_EQ(1,count(v,1));
        ASSERT_EQ(1,count(v,2));
        ASSERT_EQ(1,count(v,3));
        ASSERT_EQ(1,count(v,4));
Run Code Online (Sandbox Code Playgroud)

}

当我运行这些测试时,第一个测试通过,但第二个测试返回向量中数字1的0个实例,其中答案应为1个实例.

c++ iterator set-union

3
推荐指数
1
解决办法
600
查看次数

标签 统计

c++ ×1

iterator ×1

set-union ×1