Я пишу простую программу для поиска анаграмм. Я использую хеш-таблицу с отсортированными строками в качестве ключей и несортированными строками в качестве значений. Когда я пытаюсь напечатать unordered_map (hash map), это выдает мне эту ошибку.
Ошибка 1 ошибка C2675: унарный ‘++’: ‘std :: string’ не определяет это
оператор или преобразование в тип, приемлемый для предопределенного
оператор c: \ программные файлы (x86) \ Microsoft Visual Studio
12.0 \ vc \ include \ xhash 672 1
#include <iostream>
#include <list>
#include <cstdlib>
#include <map>
#include <string>
#include <vector>
#include <unordered_map>
#include <algorithm>
#include <cstring>void Anagrams(std::vector<std::string> &v){
std::unordered_map<std::string, std::string> wordTable;
char sortedString[256];
for (std::string tmp : v){
strcpy(sortedString, tmp.c_str());
std::sort(sortedString, sortedString + tmp.size());
std::string backToString(sortedString);
wordTable.insert(backToString, tmp);
}
std::cout << "Map contains" << std::endl;std::cout << "mymap's buckets contain:\n";
for (unsigned i = 0; i < wordTable.bucket_count(); ++i) {
std::cout << "bucket #" << i << " contains:";
for (auto local_it = wordTable.begin(i); local_it != wordTable.end(i); ++local_it)
std::cout << " " << local_it->first << ":" << local_it->second;
std::cout << std::endl;
}}int main()
{
std::vector<std::string> words{ "debitcard", "badcredit", "cat", "act", "evils", "elvis" };
Anagrams(words);return 0;}
По какой-то причине он считает, что итератор local_it является строкой. Кто-нибудь может помочь?
Проблема в том, что станд :: unorderd_map :: вставка () функция занимает std::pair<key, value>
не key, value
:
wordTable.insert(std::make_pair(backToString, tmp));
Других решений пока нет …