[프로그래머스]/python
[프로그래머스] 코딩테스트 연습>연습문제>이상한 문자 만들기
0_TLS
2024. 2. 17. 02:34
문제 보기
더보기
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 사항
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예
sreturn"try hello world" | "TrY HeLlO WoRlD" |
입출력 예 설명
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
<나의 코드> - 실패
def solution(s):
answer = ''
s = list(s.split(' '))
for i in s:
for j in range(len(i)):
if j % 2 == 1:
answer += i[j].lower()
else:
answer += i[j].upper()
answer += " "
return answer.rstrip()
<수정> - 정답
def solution(s):
answer = []
words = s.split(" ")
for word in words:
w = ""
for i in range(len(word)):
if i % 2:
w += word[i].lower()
else:
w += word[i].upper()
answer.append(w)
return ' '.join(answer)