5

我有一个地图,其中包含一个 int 和一对嵌套的两个字符串:

map<int, pair<string, string> > books;

我还有一个字符串向量。

vector<string> returned;  

以及伴随它们的两个迭代器:

vector<string> returned::iterator it2; 
map<int, pair<string, string> >::iterator it3; 

我正在尝试访问嵌套在映射中的对的第一个字符串,以将其与“返回”向量的当前字符串进行比较。我正在使用两个迭代器来做到这一点。但是,我似乎无法访问嵌套对的第一个字符串。

//PUT BACK BORROWED BOOKS    
for (it2 = returned.begin(); it2 != returned.end(); it2++){ 
    //SEARCH FOR POSITION OF BOOK 
    for (it3 = books.begin(); it3 != books.end(); it3++){   
                    //PROBLEM IN LINE BELOW
        if(it2 == (it3->second-> first)) 
            int bookPos = it3 -> first;  


    }
}

有谁知道如何引用这对中的第一个字符串?显然“it->second-> first”不是解决方案。

提前致谢。

4

2 回答 2

3

有两个错误。it3->second不是迭代器。同样正如评论中提到的,您正在将 it2 (迭代器)与字符串进行比较。出现错误的行应如下所示:

if(*it2 == (it3->second.first))
于 2012-12-02T19:28:59.133 回答
0

地图也是很好的查找表。映射键对应于由一对表示的两个值。下面的示例显示了如何访问键和对值。

int main()
{
typedef map<string, pair<int, int> > op_type;
op_type op = {
             {"addu", make_pair(33, 1) }
             };

vector<string> this_line;

op_type::const_iterator i = op.find(this_line[0]);
if( i != op.end() )
{
    cout << "key: " << i-first << endl;
    cout << ".first value in pair " << i->second.first << endl;
    cout << ".second value in pair " << i->second.second << endl;
}
}

打印: key: addu 33 对中的第一个值 1 对中的第二个值

于 2015-06-16T14:12:57.653 回答