250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 코드트리조별과제
- 오블완
- 의존관계
- html form
- 김영한
- 서블릿
- 오버라이딩
- 백준
- equals()
- 코딩테스트
- 프록시
- java
- @configuration
- 티스토리챌린지
- 스프링
- 스프링컨테이너
- 코드트리
- 테스트코드
- 인터페이스
- 다형성
- objecterror
- ocp
- JSON
- 싱글톤
- 추상클래스
- fielderror
- 참조변수
- http 메시지 컨버터
- DI
- HttpServletResponse
Archives
- Today
- Total
minOS
백준 2941 크로아티아 알파벳 본문
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 |