从SQL我有一个输出:

id值
123 xxx
124 xxx
124年
125 xxx

我在c++代码中处理此输出,我想分别使用123、125 ids(unique)和124,它们分别具有多个值。

基本上,我想分别存储唯一和多值ID,以后再分别检索它们。

我可以使用任何STL容器。

说container1存储唯一值

123 xxx
125 xxx

container2

124 xxx
124年

在 map 中,我可以分别拥有唯一的键值对:(123->xxx)(125->xxx)124->xxx,yyy吗?

有人可以帮助我创建更好的设计吗?

最佳答案

最简单的方法是std::map<int, std::vector<std::string> >(用您的类型替换std::string),如下所示:

#include <iostream>
#include <string>
#include <map>
#include <vector>

int main()
{
  std::map< int, std::vector< std::string > > map; // could use std::unordered_map as well for O(1) lookup if order of keys doesn't matter
  map[123].push_back("AAA");
  map[124].push_back("BBB");
  map[124].push_back("CCC");
  map[125].push_back("DDD");
  for(auto itr = map.begin(); itr!=map.end(); itr++) {
      std::cout<<itr->first<<":";
      for(auto vitr = itr->second.begin(); vitr != itr->second.end(); vitr++){
          std::cout<<*vitr<<",";
      }
      std::cout<<std::endl;
  }
}

输出:
123:AAA,
124:BBB,CCC,
125:DDD,

根据您的描述,不清楚将每个键(无论有多少个条目)都视为值列表是否可以接受。但是,如果是这样,这是最简单的方法。

09-10 04:40
查看更多