的一種方法是應用嵌套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