문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
- 제한 사항
문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다. 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
- 입출력 예
s | return __________________|_________________ "try hello world" | "TrY HeLlO WoRlD"
- 입출력 예 설명
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
- 첫번째 시도
def solution(s): answer = '' for i in range(len(s)): print(answer) if i == 0 or (i%2) == 0: answer += s[i].upper() else: answer += s[i].lower() return answer
- 두번째 시도
def solution(s): answer = '' n = 0 for i in s: if n == 0 or (n%2) == 0: answer += i.upper() else: answer += i.lower() n += 1 return answer
- 세번째 시도
def solution(s): b = s.split() answer = '' for i in range(len(b)): n = 0 for j in b[i]: if (n == 0) or (n%2 == 0): answer += j.upper() elif n%2 == 1: answer += j.lower() n += 1 if i != (len(b)-1): answer += ' ' return answer
- 네번째 시도
def solution(s): b = s.split(' ') answer = '' for i in range(len(b)): n = 0 for j in b[i]: if (n == 0) or (n%2 == 0): answer += j.upper() elif n%2 == 1: answer += j.lower() n += 1 if i != (len(b)-1): answer += ' ' return answer
- 왜 계속 틀리나 했는데 b = s.split(' ') 이 부분에서 ' '공백을 생략하고 ()로만 작성해서였다.