문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 사항- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
s | return |
"try hello world" | "TrY HeLlO WoRlD" |
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.\
문제 링크
https://programmers.co.kr/learn/courses/30/lessons/12930
코딩테스트 연습 - 이상한 문자 만들기
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을
programmers.co.kr
풀이
- 공백 기준으로 단어 구별해서 각 단어마다 변경 후 끝에 공백 추가
- 마지막 단어 끝에도 추가되므로 자르기
def solution(s):
answer = []
# 공백으로 단어 구별
num = s.split(" ")
for i in num:
# 단어마다 대문자, 소문자 변환
for j in range(len(i)):
if j % 2 == 0:
answer.append(i[j].upper())
else:
answer.append(i[j].lower())
# 단어 뒤에 공백 추가
answer.append(" ")
# 마지막 단어 뒤에도 공백 추가되므로 제거
return "".join(answer[:-1])
'개발 > algorithm' 카테고리의 다른 글
[프로그래머스][level 1] 같은 숫자는 싫어 - python (0) | 2021.12.07 |
---|---|
[프로그래머스] [level 1] 가운데 글자 가져오기 - python (0) | 2021.12.07 |
[프로그래머스][level 1] 문자열 내 마음대로 정렬하기 - python (0) | 2021.12.07 |
[프로그래머스][level 1] 소수 찾기 - python (0) | 2021.12.07 |
[프로그래머스][ level 1] 서울에서 김서방 찾기 - python (0) | 2021.12.07 |