1

我有一个字符向量,我想复制字符串向量中的元素。我希望第二个向量的每个单元格都有第一个向量的k个元素,形成一个字符串。尽管我没有编译错误,但程序在形成字符串向量时会崩溃。

提前致谢!

vector<string> v2;

for(int i = 0; i <= v1.size(); i++){    //v1 is the char vector

    for(int j = 0; j <= k; j++){
        v2[i] = v2[i] + v1[j];
    }

    cout << v2[i] << endl;
}
4

3 回答 3

2

当您访问时,您的向量v2是空v2[i]的:因此,此操作是非法的。你可能想要类似的东西

std::vector<std::string> v2;
v2.reserve(v1.size()); // optionally reserve enough elements; may improve performance
for (std::string::const_iterator it(v1.begin()), end(v1.end()); it != end; ++it) {
    v2.push_back(std::string(it, it + std::min(k, std::distance(it, end))));
    std::cout << v2.back() << '\n';
}
于 2013-10-25T00:29:21.220 回答
2

您必须确保您的其他向量中有足够的元素。

(更新:对 v2 使用后缀操作将节省内存和运行时间,因为在这种情况下,不必分配临时变量来执行加法操作。)

vector <string> v2(v1.size());
for(int i=0;i<=v1.size();i++){    //v1 is the char vector
    for (int j=0;j<=k;j++){
        v2[i]+=v1[j];
    }
cout<<v2[i]<<endl;
}
于 2013-10-25T00:29:34.473 回答
1

有一个带有一对迭代器的字符串构造函数——用它来抓取k连续的字符。然后,在最后一个字符串结束的地方开始下一个字符串(我认为这就是你的问题的意思?)

vector<string> v2;

auto p1 = v1.begin();
auto const pend = v1.end();
if (v1.size() > k) {
    auto const pendk = pend - k;
    do {
        auto const p2 = p1 + k; // locate k characters
        v2.emplace_back(p1, p2);// make a string from those characters
        p1 = p2;                // the end of this one is the start of the next
    } while (p1 < pendk);
}
if (p1 != pend)             // deal with any leftover (<= k) characters at the end
    v2.emplace_back(p1, pend);
于 2013-10-25T00:54:53.493 回答