Notice
Recent Posts
Recent Comments
Link
«   2025/08   »
1 2
3 4 5 6 7 8 9
10 11 12 13 14 15 16
17 18 19 20 21 22 23
24 25 26 27 28 29 30
31
Archives
Today
Total
관리 메뉴

코딩로그

[백준/BOJ/C++] 2941번 크로아티아 알파벳 본문

YJ/C++

[백준/BOJ/C++] 2941번 크로아티아 알파벳

Team DAON 2021. 11. 12. 15:14

[문제]

예전에는 운영체제에서 크로아티아 알파벳을 입력할 수가 없었다. 따라서, 다음과 같이 크로아티아 알파벳을 변경해서 입력했다.

크로아티아 알파벳 변경
č c=
ć c-
dz=
đ d-
lj lj
nj nj
š s=
ž z=

예를 들어, ljes=njak은 크로아티아 알파벳 6개(lj, e, š, nj, a, k)로 이루어져 있다. 단어가 주어졌을 때, 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.

dž는 무조건 하나의 알파벳으로 쓰이고, d와 ž가 분리된 것으로 보지 않는다. lj와 nj도 마찬가지이다. 위 목록에 없는 알파벳은 한 글자씩 센다.

[입력]

첫째 줄에 최대 100글자의 단어가 주어진다. 알파벳 소문자와 '-', '='로만 이루어져 있다.

단어는 크로아티아 알파벳으로 이루어져 있다. 문제 설명의 표에 나와있는 알파벳은 변경된 형태로 입력된다.

[출력]

입력으로 주어진 단어가 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.

[Source Code]

#include <stdio.h>
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;

int main() {
	string input;
	cin >> input;
	int count = 0;
	int i = 0;
	
	while(i < input.length()){
		if(input[i] == 'c'){
			if(input[i+1] == '=' || input[i+1] == '-')
				i++;
		}
		else if(input[i] == 'd'){
			if(input[i+1] == 'z' && input[i+2] == '=')
				i+= 2;
			else if(input[i+1] == '-')
				i++;
		}
		else if(input[i] == 'l' && input[i+1] == 'j')
			i++;
		else if(input[i] == 'n' && input[i+1] == 'j')
			i++;
		else if(input[i] == 's' && input[i+1] == '=')
			i++;
		else if(input[i] == 'z' && input[i+1] == '=')
			i++;

		i++;
		count++;
	}

	cout << count;
}

[결과 화면]