地圖我想要實現的標準::地圖上該搜索下面的函數(findn)找到的元素。但在我的情況下,關鍵是複合值,它是一個<int,int>
C++ 11搜索一個std ::複合鍵
如何在這裏使用std::map.find
?
#include <iostream>
#include <map>
#include <utility>
#include <string>
using namespace std;
std::map<std::pair<int, int>, std::string> studentMap;
int insert(int i, int j, std::string name) {
if(!studentMap.insert(std::make_pair (std::make_pair(i,j), name)).second) {
std::cout << "game not added" << std::endl;
} else {
std::cout << "game added" << std::endl;
}
return 0;
}
void findn(int i, int j) {
// how to find when we have composite key?
}
int main() {
insert(1,1,"test");
insert(1,1,"tes");
insert(1,2,"test 2");
std::cout << studentMap.size() << std::endl;
findn(1,1);
}
如果鑰匙*不*一個'的std :: pair',你會怎麼做呢?是什麼讓你覺得在這種情況下會有所不同? –
我只是問正常的查找方法是否適用於組合鍵。 – cateof
只要先嚐試一下就簡單了。 :) –