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 |
Tags
- 스프링컨테이너
- 추상클래스
- 코딩테스트
- 코드트리
- 코드트리조별과제
- 인터페이스
- 오블완
- 다익스트라
- 싱글톤
- DI
- 프로그래머스
- html form
- 참조변수
- @configuration
- http 메시지 컨버터
- 티스토리챌린지
- 백준
- 프록시
- 스프링
- java
- 김영한
- objecterror
- 테스트코드
- 예외와 트랜잭션 커밋
- 의존관계
- HttpServletResponse
- 서블릿
- equals()
- 오버라이딩
- fielderror
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 > 백준' 카테고리의 다른 글
| 백준 1719 택배 (0) | 2025.07.06 |
|---|---|
| 백준 5567 결혼식 (1) | 2024.12.30 |
| 백준 15686 치킨 배달 (2) | 2024.11.14 |
| 백준 2096 내려가기 (0) | 2024.01.06 |
| 백준 2075 N번째 큰 수 (0) | 2024.01.04 |