C++ STL map,std :: pair作为键

Avi*_*ash 4 c++ stl

这就是我通过map定义的方式.

std::map<std::pair<std::string,std::string>, int>  edMap;
Run Code Online (Sandbox Code Playgroud)

我对如何插入值感到困惑,我总是遇到编译错误.这就是我试图插入的方式.

    std::pair<std::string,std::string> key;
    edMap.insert(key,d);
Run Code Online (Sandbox Code Playgroud)

编译错误是

1>------ Build started: Project: spellsuggest, Configuration: Debug Win32 ------
1>Compiling...
1>breathalyzer.cpp
1>d:\personal\spellsuggest\spellsuggest\breathalyzer.cpp(70) : error C2664: 'std::_Tree<_Traits>::iterator std::_Tree<_Traits>::insert(std::_Tree<_Traits>::iterator,const std::pair<_Ty1,_Ty2> &)' : cannot convert parameter 1 from 'std::pair<_Ty1,_Ty2>' to 'std::_Tree<_Traits>::iterator'
1>        with
1>        [
1>            _Traits=std::_Tmap_traits<std::pair<std::string,std::string>,int,std::less<std::pair<std::string,std::string>>,std::allocator<std::pair<const std::pair<std::string,std::string>,int>>,false>,
1>            _Ty1=const std::pair<std::string,std::string>,
1>            _Ty2=int
1>        ]
1>        and
1>        [
1>            _Ty1=std::string,
1>            _Ty2=std::string
1>        ]
1>        and
1>        [
1>            _Traits=std::_Tmap_traits<std::pair<std::string,std::string>,int,std::less<std::pair<std::string,std::string>>,std::allocator<std::pair<const std::pair<std::string,std::string>,int>>,false>
1>        ]
1>        No user-defined-conversion operator available that can perform this conversion, or the operator cannot be called
1>Build log was saved at "file://d:\personal\spellsuggest\spellsuggest\Debug\BuildLog.htm"
1>spellsuggest - 1 error(s), 0 warning(s)
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========
Run Code Online (Sandbox Code Playgroud)

Ker*_* SB 13

我们试试吧:

typedef std::pair<std::string, std::string> my_key_type;
typedef std::map<my_key_type, int>          my_map_type;

my_map_type m;

m.insert(my_map_type::value_type(my_key_type("A", "B"), 43));
Run Code Online (Sandbox Code Playgroud)

观察地图value_type是永远的std::pair<const key_type, mapped_type>,所以在你的情况下它是std::pair<my_key_type, int>- 一对其第一个成员本身就是一对!

考虑到这一点,你可以选择使用make_pair:

m.insert(std::make_pair(my_key_type("C", "D"), -5));
Run Code Online (Sandbox Code Playgroud)

最后,正如Sven指出的那样,对可能有也可能没有比较运算符(我认为有); 所以,如果没有,你必须自己写一个.应该对这两个要素进行字典比较.索菲等待着:-)

(这是词典对比较; 你不需要写这个,它已经存在了 :)

template<typename S, typename T>
bool operator<(const std::pair<S, T> & a, const std::pair<S, T> & b)
{
   return (a.first < b.first) || (a.first == b.first && a.second < b.second);
}
Run Code Online (Sandbox Code Playgroud)