728x90
문제 설명
문자열 s는 한 개 이상의 단어로 구성되어 있습니다. 각 단어는 하나 이상의 공백문자로 구분되어 있습니다. 각 단어의 짝수번째 알파벳은 대문자로, 홀수번째 알파벳은 소문자로 바꾼 문자열을 리턴하는 함수, solution을 완성하세요.
제한 사항- 문자열 전체의 짝/홀수 인덱스가 아니라, 단어(공백을 기준)별로 짝/홀수 인덱스를 판단해야합니다.
- 첫 번째 글자는 0번째 인덱스로 보아 짝수번째 알파벳으로 처리해야 합니다.
"try hello world" | "TrY HeLlO WoRlD" |
"try hello world"는 세 단어 "try", "hello", "world"로 구성되어 있습니다. 각 단어의 짝수번째 문자를 대문자로, 홀수번째 문자를 소문자로 바꾸면 "TrY", "HeLlO", "WoRlD"입니다. 따라서 "TrY HeLlO WoRlD" 를 리턴합니다.
<풀이>
def solution(s):
ss = s.split(" ")
answer = ''
for i in range(len(ss)):
for j in range(len(ss[i])):
if j % 2 == 0:
answer += ss[i][j].upper()
else:
answer += ss[i][j].lower()
if i != len(ss) - 1:
answer += ' '
return answer
def solution(s):
s_split = s.split(" ") # 받은 문자열을 단어별(스페이스 기준)으로 split해서 list에 넣어주기
for k in range(len(s_split)): # 단어 리스트에 있는 단어들 반복할 때 그 단어 길이 만큼 반복문
s_list = list(s_split[k]) # 문자열을 새로 만들어야 하니 s_list라는 리스트에 입력
for i in range(len(s_list)): # 단어 리스트에 있는 단어들 반복할 때 그 단어 길이 만큼 반복문
if i % 2 == 0:
s_list[i] = s_list[i].upper() # 단어가 홀수면 대문자로 바꿔서 리스트에 붙여주기
elif i % 2 == 1:
s_list[i] = s_list[i].lower() # 단어가 짝수면 소문자로 바꿔서 리스트에 붙여주기
s_split[k] = "".join(s_list)
answer = " ".join(s_split) # 새로 채워진 list s_split에 있는 요소들 붙여서 return (스페이스 중간에 넣어주기)
return answer
1. 공백(" ")을 기준으로 문자열을 나누기
2. 문자열을 받아서 인덱스가 짝수면 대문자로, 홀수면 소문자로 문자열 지정 => 2로 나눈 나머지가 0이면 짝수로 대문자, 아니면 홀수로 소문자
2-1) 대문자로 만들기 위해 .upper() 함수 사용
2-2) 소문자로 만들기 위해 .lower() 함수 사용
3. 한 문자열의 판단이 끝나면 공백을 추가
4. 결과의 마지막 공백은 제거후 리턴
[TrY, HeLlO, WoRlD]가 된다. 여기서 (" ").join으로 문자열을 합쳐서 반환하자.
728x90
'CodingTest > [프로그래머스 LV.1]' 카테고리의 다른 글
프로그래머스 LV.1 - 과일로 만든 아이스크림 고르기[MySQL] (0) | 2023.02.03 |
---|---|
프로그래머스 LV.1 - 예산[Python] (0) | 2023.02.03 |
프로그래머스 LV.1 - 3진법 뒤집기[Python] (0) | 2023.02.02 |
프로그래머스 LV.1 - 최댓값 구하기[MySQL] (0) | 2023.02.02 |
프로그래머스 LV.1 - 같은 숫자는 싫어[Python] (0) | 2023.02.02 |