使用 C++ 和 STL 函数查找并打印 std::vector 中的重复单词。
假设我们有一份字符串列表。该列表中有一些重复的字符串。我们必须检查哪些字符串出现多次。假设字符串列表像是 [“Hello”, “Kite”, “Hello”, “C++”, “Tom”, “C++”]
这里我们将使用哈希技术,创建一个空的哈希表,然后遍历每个字符串,对于每个字符串,如果 s 在哈希表中已经存在,则显示该字符串,否则插入到哈希表中。
示例
#include<iostream>
#include<vector>
#include<unordered_set>
using namespace std;
void displayDupliateStrings(vector<string> strings) {
unordered_set<string> s;
bool hasDuplicate = false;
for (int i = 0; i<strings.size(); i++) {
if (s.find(strings[i]) != s.end()) {
cout << strings[i] << endl;
hasDuplicate = true;
}
else
s.insert(strings[i]);
}
if (!hasDuplicate)
cout << "No Duplicate string has found" << endl;
}
int main() {
vector<string>strings{"Hello", "Kite", "Hello", "C++", "Tom", "C++"};
displayDupliateStrings(strings);
}输出
Hello C++
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP