如何将函数应用于地图的每个值以创建排序序列?

时间:2012-08-03 18:47:19

标签: c++ stdstring stdmap stl-algorithm

在C ++中使用STL,我如何将函数应用于std::map中的每个值以获得std::string(值的打印表示)并收集std::string( s)进入一个按浮点键排序的集合,该浮点键来自应用于地图中每个相应值的另一个函数?

换句话说,我想迭代映射中的键值对并创建一组新的键值对,其中新键和值是旧值的函数。

double getNewKey(origValue value);
std::string getNewValue(origValue value);
// Or is it better to map both at once in a pair?
std::pair<double, std::string> getNewPair(origValue value);

std::map<origKey, origValue> origMap;

// Perform some transformation on each value of origMap to get a new map:
std::map<double, std::string> transformedMap =
  /* What goes here to use getNewKey() and getNewValue() or use getNewPair()? */
  ;

但是,请不要使用C ++ 11。

2 个答案:

答案 0 :(得分:3)

std::transform就是您所需要的:

#include <map>
#include <algorithm>
#include <iterator>
#include <iostream>

// using a few C++11 features to make life easier
int main(){
  std::map<int, int> src, dst; // example KV pair
  for(unsigned i=0; i < 10; ++i)
    src[i] = i;
  typedef std::map<int, int>::value_type kv_pair;
  std::transform(src.begin(), src.end(), std::inserter(dst, dst.begin()),
      [](kv_pair const& p){
        return kv_pair(p.first, p.second * 2);
      });
  for(auto& p : dst)
    std::cout << p.first << " : " << p.second << "\n";
}

Live example.

答案 1 :(得分:1)

[免责声明,未经测试]:

std::pair<NewKey,NewValue> transform( std::pair<const OldKey,OldValue> const & x ) {
   return std::make_pair( getNewKey(x.first), getNewValue(x.second) );
}
...
std::transfom( m.begin(), m.end(),
               std::inserter( newmap, m.end() ),
               transform );