是否有可能用STL算法来深拷贝一个std ::地图值一个std ::集?
我不想在新的集显式插入。
我不想明确地做到这一点:
std::map<int, double*> myMap; //filled with something
std::set<double*> mySet;
for (std::map<int, double*>::iterator iter = myMap.begin(); iter!=myMap.end(); ++iter)
{
mySet.insert(iter->second);
}
但找到一个更coincise和优雅的方式来做到这一点,其值的深层副本。
那这个呢?
std::transform(myMap.begin(), myMap.end(), std::inserter(mySet, mySet.begin()),
[](const std::pair<int, double*>& key_value) {
return key_value.second;
});
这仅复制三分球,虽然。 如果你想有一个深拷贝,那么你就需要做:
std::transform(myMap.begin(), myMap.end(), std::inserter(mySet, mySet.begin()),
[](const std::pair<int, double*>& key_value) {
return new double(*key_value.second);
});
顺便说一句,该代码使用lambda函数(仅可得自C ++ 11)。 如果您不能使用C ++ 11,你可以用一个函数对象 ,虽然。