문제설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
시도했던 solution
def solution(s): answer = '' str = s.split() #먼저 공백을 기준으로 자른다. s = list(map(int, str)) for i in range(0,2): s[i]%2==0 else: s.lower() return answer
정말 형편없는 코드다. 리스트로 변환하는 것, 문자열을 정수로 변환하는 것, 대/소문자로 변환하는 법, 공백을 기준으로 자르는 것,, 등 학습해야 할 게 너무도 많은 문제였다. 코드도 상당히 길게 작성해야 할 것 같았다. 그래서 결국은 다른 풀이를 보게 되었다.
solution
def solution(s): answer = [] s = s.split(' ') for i in range(len(s)): result = '' for j in range(len(s[i])): if j % 2 == 0: result += s[i][j].upper() else: result += s[i][j].lower() answer.append(result) return ' '.join(answer)
한 줄 풀이도 봤는데 대단하다... 내 수준은 한줄 코드로 작성하기까지 한참 멀었지만 언젠간은 정말 간단하고 쉬운 풀이를 제공할 것이다.
한줄 풀이
def solution(s): return " ".join(map(lambda x: "".join([a.lower() if i % 2 else a.upper() for i, a in enumerate(x)]), s.split(" ")))
조금 더 끈기있게 해보는 건 어떨까? 하루에 한 개씩 코딩테스트를 하려는 부담감 때문에 그런 거라고 생각한다. 여유를 가지고 해보자.