在地图中使用矢量时出错

时间:2016-04-19 21:15:41

标签: c++ vector

我正在尝试根据键将矢量添加到地图中的位置。

vector<string> words;
map<string, vector<string>> wordMap;

for (int i = 0; i < words.size(); i++) {
    string word = words.at(i);

    if (wordMap.find(word) == wordMap.end())
        wordMap.insert(make_pair(word, vector<string>()));

    vector<string> context = { "EMPTY" };

    if (i == 0)
        context = { "Beginning of words", words[i + 1], words[i + 2] };
    else if(i == 1)
        context = { "Beginning of words", words[i - 1], words[i + 1], words[i + 2] };
    else if (i == words.size() - 2)
        context = { words[i - 2], words[i - 1], words[i + 1], "End of words" };
    else if(i == words.size() - 1)
        context = { words[i - 2], words[i - 1], "End of words" };
    else
        context = { words[i - 2], words[i - 1], words[i + 1], words[i + 2] };

    wordMap[word].push_back(context);
    cout << context[0] << endl;
}

我在

期间一直收到以下错误
wordMap[word].push_back(context);

Error: no instance of overloaded function "std::vector<_Ty,_Alloc>::push_back[with_Ty=std::string,_Alloc=std::allocator<std::string>]" matches the argument list 
argument types are: (std::vector<std::string, std::allocator<std::string>>) 
object type is std::vector<std::string, std::allocator<std::string>>

程序中的其他所有内容都可以使用,如果您需要我可以发布它,但唯一的错误是当我尝试使用push_back时。我需要使用push_back,因为我无法重新分配值。我必须保留所有先前的值位于该键,因此push_back是理想的。非常感谢任何帮助。

2 个答案:

答案 0 :(得分:10)

而不是:

wordMap[word].push_back(context);

你应该追加新的载体:

std::copy(context.begin(), context.end(), std::back_inserter(wordMap[word]));

另一件事是你真的不需要这个初始化:

if (wordMap.find(word) == wordMap.end())
        wordMap.insert(make_pair(word, vector<string>()));

稍后wordMap[word]将添加值初始化元素。

operator[]实例上调用map时,如果给定键上没有值,则始终添加一个新元素,然后返回对它的引用。

答案 1 :(得分:-1)

编辑: 问题发生是因为wordMap[word]的类型为vector<string>且调用push_back是正确的,但您需要提供类型为string的值为push_back,但此处为wordMap[word].push_back(context);,类型context的{​​{1}}。{/ p>

也许改变是这样的:

vector<string>

此外,我会使用指针,因为可能更好地存储指向堆中的字符串向量而不是堆栈中的字符串ex:

for(vector<string>::iterator iter = context.begin(); iter != context.end(); iter++) {
    wordMap[word].push_back(*iter);
}