做题的时候发现一个问题,我要将一个string 反转过来,并在哈希表进行查询
// mp中的每个string 保证大小为2
map<string, int> mp;
int res = 0;
for (auto s : mp) {
string ss = s[1] + s[0];
if (mp.count(ss)) res ++;
}
这种情况给我报了个错误,说是没有char 到 string的转换。
当时给我看懵了,这里用一个string记录原来的s 再reverse(s.begin(), s.end())也是可以的,不是这里要讨论的问题,然后查阅了一下string的构造函数,确实没有char直接变为string,不知道为什么没有;
可以用
ss.push_back(s[1]); ss.push_back(s[0]);
来进行添加,
或者
string ss = string(1,s[1]) + string(1,s[0]);
string的构造函数如下:
string();
string (const string& str);
string (const string& str, size_t pos, size_t len = npos);
string (const char* s);
string (const char* s, size_t n);
string (size_t n, char c);
template <class InputIterator>
string (InputIterator first, InputIterator last);
string (initializer_list<char> il);
string (string&& str) noexcept;