的一种方法是应用嵌套std::accumulate两次,一次用于总结阵列和对于每个阵列来总结地图内容:
struct Test
{
string id;
long date;
bool operator<(Test const& test) const
{
if(date == test.date)
return id < test.id;
return date < test.date;
}
};
double sum_per_id(std::array<std::map<Test, double>, 2> const& testMapArray,
std::string const& id)
{
return std::accumulate(std::begin(testMapArray), std::end(testMapArray), 0.0,
[&id](double d, std::map<Test, double> const& testMap)
{
return d + std::accumulate(std::begin(testMap), std::end(testMap), 0.0,
[&id](double d, std::map<Test, double>::value_type const& p)
{
if(id == p.first.id)
return d + p.second;
return d;
});
});
}
int main()
{
std::array<std::map<Test, double>, 2> testMapArray;
testMapArray[0][{"A", 0}] = 0.1;
testMapArray[0][{"B", 1}] = 0.2;
testMapArray[1][{"A", 2}] = 0.3;
testMapArray[1][{"B", 3}] = 0.4;
std::cout << "sum: " << sum_per_id(testMapArray, "A") << '\n';
}
输出:
sum: 0.4
有没有你不使用这样的理由:地图 testMap [2]; ? –
user
对于每个ID,我们可能在不同的日期有不同的交易。所以将地图关键字作为ID和日期的组合。 – user1706047
好像'地图<串,对<矢量,长>> test_map [2]'可能在该特定情况下更好地工作。 –
evan