문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 사항
- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
입출력 예
s |
return |
"try hello world" |
"TrY HeLlO WoRlD" |
풀이
def solution(s):
answer = ''
for i in s.split(' '):
for j in range(len(i)):
if j % 2 == 0:
answer += i[j].upper()
else:
answer += i[j].lower()
answer += ' '
return answer[0:-1]
- 단어마다 인덱스를 나눠야 하므로 먼저 split(’ ‘)을 이용해 공백별로 나눠줌
- 이중 for문을 사용해서 단어별로 홀/짝 인덱스에 따라 소문자,대문자로 바꿔줌
- return할 때는 원래의 문자열처럼 공백이 있어야하므로 안쪽 for문이 끝날 때마다(즉, 단어 하나가 끝날 때마다) 띄어쓰기
- 한 가지 의문은, return 값에 answer.strip(’ ‘)로 하면 왜 틀리는 건지
Uploaded by Notion2Tistory v1.1.0