0

「const char *arr1[ArrSize] = {"Blah1", "Wibble1", "Shrug1"};」のような 2 つの char 配列があります。それらをベクトルに入れるために、すてきな簡単な解決策を見つけました:

void fillVecTest()
{
    const int ArrSize = 3;
    const char *arr1[ArrSize] = {"Blah1", "Wibble1", "Shrug1"};
    const char *arr2[ArrSize] = {"Blah2", "Wibble2", "Shrug2"};
    std::vector<std::string> vec1(arr1, arr1+ArrSize);
    std::vector<std::string> vec2(arr2, arr2+ArrSize);
    std::vector<std::string>::iterator l_It1Vec1;
    std::vector<std::string>::iterator l_It = vec1.end();
    l_It = find(vec1.begin(), vec1.end(), std::string("Blah1"));
    if(l_It != vec1.end())
    {
      size_t l_pos = l_It - vec1.begin();
      printf("found %s, pos=%u val: %s\n", l_It->c_str(),l_pos, vec2[l_pos].c_str());
    }
 }

arr1 がキーで arr2 が値であるため、両方をマップに直接配置することも可能であると考えました。いくつかの方法を試しましたが、成功しませんでした。

void fillMapTest()
{
    const int ArrSize = 3;
    const char *arr1[ArrSize] = {"Blah1", "Wibble1", "Shrug1"};
    const char *arr2[ArrSize] = {"Blah2", "Wibble2", "Shrug2"};
    std::map<std::string,std::string> map1;//(pair(arr1,arr1), pair(arr1+ArrSize,arr2+ArrSize));
    std::map<std::string,std::string>::iterator l_It1Map1;
    //l_It1Map1 = find(map1.begin(), map1.end(), std::string("Blah1"));
    if(l_It1Map1 != map1.end())
    {
      printf("found key: %s, val: %s\n",l_It1Map1->first.c_str(), l_It1Map1->second.c_str());
    }

}


int _tmain(int /*argc*/, _TCHAR* /*argv[]*/)
{
  fillVecTest();
  fillMapTest();
  return 0;
}

関数「fillMapTest」のコメント行だけを解決する必要があると思います。コンストラクターと find が思い通りに動作しません。

STLの専門家にアイデアはありますか?

4

3 に答える 3

5

これを書く最も簡単な方法:

std::map<std::string, std::string> m {
    { "key1", "value1" },
    { "key2", "value2" },
};

これには、コンパイラが初期化子リスト(C++11 の機能) をサポートする必要があります。

于 2013-05-14T17:03:55.863 に答える
0
for(int i = 0; i < ArrSize; i++) {
    m.insert(pair<string, string>(arr1[i], arr2[i]));
}
于 2013-05-14T17:20:42.483 に答える