如何在 STL 载体上仅保留重复项<string>?
How to keep only duplicates on a STL vector<string>?
给定stl向量,仅输出重复:
INPUT {"A","A","B","B","C","D","E","F"};
OUTPUT {"A","B"}
我真的是STL的新手,所以不知道从哪里开始。有人可以将我指向正确的方向吗?
一种明显的方法是浏览输入,并在地图中计数它们。然后浏览地图并输出每个数量大于一个的字符串。
map<string, int> counts;
for (auto const &s : input)
++counts[s];
for (auto const &s : counts)
if (s.second > 1)
outputs.push_back(s.first);
另一种可能性(如果需要维护原始订单,尤其有用)是在您浏览输入时将字符串插入集合(或Unordered_set)中。然后,如果失败,字符串已经在集合中,则将其写入输出。
如果(我猜是这样),您只希望每个重复的项目出现在输出中一次,则可能需要将其更改为布尔值地图。当您最初插入项目时,布尔值将设置为false。您第二次看到该项目,您将检查布尔值。当该错误时,写出项目,然后将其设置为true。如果是真的,那意味着它已经写了,所以不要再写了。
相关文章:
- 请解释这句话(cout<<1+int((a<b)^((b-a)&1) )<<endl
- 呼叫运营商<<临时
- cppcheck在const std::string[]上引发警告
- 将std::string传递给WriteConsole API
- 如何防止clang格式在流运算符调用之间添加换行符<<
- 为std::string的某个索引赋值
- <<操作员在下面的行中工作
- std中有类似find_last_of的函数,而string中没有
- 使用 std::string () const 函数启动线程或未来
- 使用char类型将decimal转换为string,将string转换为decimal
- 迭代和比较映射<字符串、矢量<string>> c++ 中的值
- 当我们进行一些操作时,应该使用什么'std::string'或'std::stringstream'?
- 将向量解析<string>为字符串
- 'string.assign(string.data(), 5)' 是明确定义的还是 UB?
- 如何更改大小(std::string)
- "string.h"在构建适用于iOS的qt应用程序中找不到消息
- C++:如何将 unix 时间的字符串转换为 *tm?(使用时间错误:"cannot convert 'String' to 'tm*' ")
- std::string 的对象真的可以移动吗?
- 与'operator='不匹配(操作数类型'String'且"void")
- SegFault 同时使用 std::string::operator+= 和函数作为参数