Computer >> 컴퓨터 >  >> 프로그램 작성 >> C++

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++