2021 카카오 채용연계형 인턴십 >숫자 문자열과 영단어
코딩테스트 연습 - 숫자 문자열과 영단어
네오와 프로도가 숫자놀이를 하고 있습니다. 네오가 프로도에게 숫자를 건넬 때 일부 자릿수를 영단어로 바꾼 카드를 건네주면 프로도는 원래 숫자를 찾는 게임입니다. 다음은 숫자의 일부 자
programmers.co.kr
나의 풀이
- 너무 복잡하게 풀었다.. 😥
def solution(s):
number = ["zero", "one", "two", "three", "four", "five","six" ,"seven","eight","nine"]
answer = 0
while s:
if '0' <= s[0] <= '9':
answer = answer*10 + int(s[0])
s = s[1:]
for i in range(len(number)):
if number[i] == s[:len(number[i])]:
answer = answer*10 +i
s = s[len(number[i]):]
break
return answer
다른 사람의 풀이
--> replace 함수를 사용하여 간단하게 코드 작성
- 문자열.replace("검색 문자", "치환 문자", 치환 횟수)
치환 횟수는 생략 가능
num_dic = {"zero":"0", "one":"1", "two":"2", "three":"3", "four":"4", "five":"5", "six":"6", "seven":"7", "eight":"8", "nine":"9"}
def solution(s):
answer = s
for key, value in num_dic.items():
answer = answer.replace(key, value)
return int(answer)
'study > 알고리즘' 카테고리의 다른 글
[알고리즘/프로그래머스] 비밀지도 (0) | 2021.12.17 |
---|---|
[알고리즘/프로그래머스] 튜플 (0) | 2021.12.16 |
[알고리즘/백준] 11724번 연결 요소의 개수 (0) | 2021.12.10 |
[알고리즘/백준] 2644번 촌수계산 (0) | 2021.12.09 |
[알고리즘] 다이나믹 프로그래밍(LIS) - 병사 배치하기 (0) | 2021.12.08 |