3

您能否向我解释一下我在以下代码中做错了什么?我希望第二个向量中的值> = 80,但它是空的。

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

class Tester
{
    public:
        int value;
        Tester(int foo)
        {
            value = foo;
        }
};

bool compare(Tester temp)
{
    if (temp.value < 80)
        return true;
    else
        return false;
}

int main()
{
    vector<Tester> vec1;
    vector<Tester> vec2;
    vec1.reserve(100);
    vec2.reserve(100);

    for(int foo=0; foo<100; ++foo)
        vec1.push_back(Tester(foo));

    remove_copy_if(vec1.begin(), vec1.end(), vec2.begin(), compare);

    cout<< "Size: " << vec2.size() << endl;

    cout<< "Elements"<<endl;
    for(int foo=0; foo < vec2.size(); ++foo)
        cout << vec2.at(foo).value << " ";
    cout<<endl;

    return 0;
}
4

2 回答 2

6

该函数std::remove_copy_if()将不匹配的元素从一个序列复制到另一个序列。通话

remove_copy_if(vec1.begin(), vec1.end(), vec2.begin(), compare);

假设有一个合适的序列开始,vec2.begin()实际上并非如此:什么都没有。如果没有任何内存reserve()dvec2可能会导致崩溃。你想要的是一个迭代器,它可以根据需要扩展序列:

std::remove_copy_if(vec1.begin(), vec1.end(), std::back_inserter(vec2), compare);

有了这个调用reserve()不是必需的,而只是潜在的性能优化。

于 2012-08-20T23:50:56.730 回答
4

标准算法适用于迭代器,并且对这些迭代器所属的容器一无所知。你vec2.begin()作为输出迭代器参数传递给remove_copy_if它,它会盲目地增加它,不知道它vec2是空的,耗尽分配的空间。您需要back_insert_iterator在调用之前传递 a 或将向量调整为合适的大小。

于 2012-08-20T23:51:28.053 回答