gpt4 book ai didi

c++ - 在 map 中查找集合的元素

转载 作者:太空狗 更新时间:2023-10-29 21:05:11 25 4
gpt4 key购买 nike

我有两个 map ,tk1tk2,结构如下:

std::map<std::string, double>tk1;
std::map<std::string, double>tk2;

tk1 包含以下数据:

    2011-01-03 2200
2011-01-04 2209
2011-01-05 2300

tk2包含以下数据:

2011-01-03 2450
2011-01-04 2465
2011-01-06 2476
2011-01-07 2457

我创建了一个集合,其中包含日期作为字符串

std::set<std::string>dateset;
std::set<std::string>new_dateset;

我通过遍历 2 个映射并将其插入到集合中来创建它

dateset.insert(it->first);

dateset 具有以下值:

2011-01-03
2011-01-04
2011-01-05
2011-01-06
2011-01-07

我想填充 new_dateset,使其只包含 tk1tk2 中的日期,即 new_dateset 应该只包含

2011-01-03
2011-01-04

我写了以下内容:

std::set<std::string>::iterator it1=dateset.begin(), end1=dateset.end();
std::map<std::string, double>::iterator it2=tk1.begin(), end2=tk1.end();
std::map<std::string, double>::iterator it3=tk2.begin(), end3=tk2.end();
while (it1 != end1) {
if (it2->first == *it1)
new_dateset.insert(it2->first);
++it1;
}

但显然我没有做对。有人可以建议最好的方法吗。

最佳答案

您可能会考虑使用来自 previous answerkey_iteratorstd::set_intersection .

关于c++ - 在 map 中查找集合的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10565723/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com