<크로아티아 알파벳>, 2941번
문제
예전에는 운영체제에서 크로아티아 알파벳을 입력할 수가 없었다. 따라서, 다음과 같이 크로아티아 알파벳을 변경해서 입력했다.
크로아티아 알파벳 변경
č c=
ć c-
dž dz=
đ d-
lj lj
nj nj
š s=
ž z=
예를 들어, ljes=njak은 크로아티아 알파벳 6개(lj, e, š, nj, a, k)로 이루어져 있다. 단어가 주어졌을 때, 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.
dž는 무조건 하나의 알파벳으로 쓰이고, d와 ž가 분리된 것으로 보지 않는다. lj와 nj도 마찬가지이다. 위 목록에 없는 알파벳은 한 글자씩 센다.
입력
첫째 줄에 최대 100글자의 단어가 주어진다. 알파벳 소문자와 '-', '='로만 이루어져 있다.
단어는 크로아티아 알파벳으로 이루어져 있다. 문제 설명의 표에 나와있는 알파벳은 변경된 형태로 입력된다.
출력
입력으로 주어진 단어가 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.
예제 입력 1
ljes=njak
예제 출력 1
6
예제 입력 2
ddz=z=
예제 출력 2
3
예제 입력 3
nljj
예제 출력 3
3
예제 입력 4
c=c=
예제 출력 4
2
풀이
이 문제는 알파벳 소문자와 -, = 으로만 이루어진 문자열을 입력받아서 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력해주는 프로그램을 제작하는 것이다. 나는 배열 a에 문자열을 저장한 후 asize 변수를 선언해서 while문을 이용해 문자열의 길이를 구한 후 for문을 돌렸다. 그 for문 안에서 if문을 사용해서 배열의 기준값과 기준값에 1을 더한 값, 또는 2를 더한 값까지 크로아티아 알파벳과 일치하는지 확인한 후 count 값을 더해 크로아티아 알파벳 값을 구해 출력하는 프로그램을 제작했다.
#include <stdio.h>
int main(void)
{
char a[102];
char count = 0;
int asize = 0;
scanf("%s", a);
while (a[asize] != '\0')
asize++;
for (int i = 0; i < asize; i++)
{
if (a[i] == 'c' && a[i + 1] == '=')
{
count++;
i += 1;
}
else if (a[i] == 'c' && a[i + 1] == '-')
{
count++;
i += 1;
}
else if (a[i] == 'd' && a[i + 1] == 'z' && a[i + 2] == '=')
{
count++;
i += 2;
}
else if (a[i] == 'd' && a[i + 1] == '-')
{
count++;
i += 1;
}
else if (a[i] == 'l' && a[i + 1] == 'j')
{
count++;
i += 1;
}
else if (a[i] == 'n' && a[i + 1] == 'j')
{
count++;
i += 1;
}
else if (a[i] == 's' && a[i + 1] == '=')
{
count++;
i += 1;
}
else if (a[i] == 'z' && a[i + 1] == '=')
{
count++;
i += 1;
}
else
count++;
}
printf("%d", count);
return 0;
}