※ 글쓴이는 취미로 코딩을 익혀보는 사람이라 정확하지 않은 내용을 담고 있을 수 있다 ※

 

이번에 볼 문제는 백준 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

+ Recent posts