minOS

백준 2941 크로아티아 알파벳 본문

Problem Solving/백준

백준 2941 크로아티아 알파벳

minOE 2024. 12. 29. 18:51
728x90

https://www.acmicpc.net/problem/2941

문제를 보고 .. dž 변경만 3자리고 나머지는 두자리라는 것이 눈에 들어와서 알파벳 검사를 3자리와 2자리 그리고 나머지
로 나누면 개수가 나올 것 이라고 생각하였습니다.
word = input()
string = {"c=", "c-","d-", "lj","nj","s=","z="}
ans =0
idx =0
while idx != len(word):
    if word[idx:idx+3] == "dz=":
        ans+=1
        idx += 3
    elif word[idx:idx+2] in string:
        ans+=1
        idx+=2
    else:
        idx+=1
        ans+=1
print(ans)​


index 를 0으로 초기화 하고, dz= 일때는 인덱스를 3번 옮기고 단어 개수도 하나 증가시킵니다.
그리고 두 자리를 검사하여 만약 string 집합에 있으면, 인덱스를 2번 옮기고 단어 개수를 하나 증가 시킵니다.
나머지 경우는 모두 알파벳 한 자리기 때문에 인덱스를 1번 옮기고 단어 개수도 하나 증가 시킵니다. 



다른 풀이를 검색해 봤는데
croatia = ['c=', 'c-', 'dz=', 'd-', 'lj', 'nj', 's=', 'z=']
word = input()

for i in croatia :
    word = word.replace(i, '*')  # input 변수와 동일한 이름의 변수
print(len(word))​

해당 풀이가 더 합리적이라고 느꼈습니다.
왜냐하면 저의 풀이는 만약 크로아티아 알파벳을 변경 후 알파벳 개수가 다양하다면 조건문을 엄청나게 써야한다는 치명적인 단점이 존재하기 때문입니다 . 이렇게 저의 문제 접근 방식이 어떨 때 불리할지 , 또는 어떤 장점이 있는지 생각해보면서 풀어보니 관점이 넓어지는 것을 느꼈습니다.
728x90

'Problem Solving > 백준' 카테고리의 다른 글

백준 5567 결혼식  (1) 2024.12.30
백준 15686 치킨 배달  (2) 2024.11.14
백준 2096 내려가기  (0) 2024.01.06
백준 2075 N번째 큰 수  (0) 2024.01.04
백준 1446 지름길  (2) 2024.01.03