※ 글쓴이는 취미로 코딩을 익혀보는 사람이라 정확하지 않은 내용을 담고 있을 수 있다 ※
이번에 볼 문제는 백준 24080번 문제인 複雑な文字列 (Complex String)이다.
문제는 아래 링크를 확인하자.
https://www.acmicpc.net/problem/24080
24080번: 複雑な文字列 (Complex String)
S に 3 種類以上の文字が出現する場合は Yes を,そうでない場合は No を出力せよ.
www.acmicpc.net
주어지는 길이 N의 문자열에 들어있는 알파벳이 3종류 이상이면 "Yes", 아니면 "No"를 출력하는 문제이다.
각 문자별로 사용했는지 아닌지를 저장하는 visited배열을 이용해 문제를 간단히 해결하자.
아래는 제출한 소스코드이다.
#include <iostream>
using namespace std;
int slen; string s;
bool visited[128];
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
int cnt = 0;
cin >> slen >> s;
for (auto& l : s) {
if (!visited[l]) visited[l] = 1, cnt++;
}
if (cnt > 2) cout << "Yes";
else cout << "No";
}
728x90
'BOJ' 카테고리의 다른 글
[BOJ 12571 // C++] Rope Intranet (Small) (0) | 2022.12.10 |
---|---|
[BOJ 12572 // C++] Rope Intranet (Large) (0) | 2022.12.10 |
[BOJ 24803 // C++] Provinces and Gold (0) | 2022.12.09 |
[BOJ 7782 // C++] Alien (0) | 2022.12.09 |
[BOJ 10168 // C++] 파발마 (0) | 2022.12.09 |