IFP_껐다 켜면 됩니다_프로그래머스 - 이상한 문자 만들기

유재우·2022년 7월 19일
0

IFP-껐다 켜면 됩니다

목록 보기
116/123

문제 설명

문자열 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(' ') 이 부분에서 ' '공백을 생략하고 ()로만 작성해서였다.

profile
끝없이 탐구하는 iOS 개발자 유재우입니다!

0개의 댓글