PS/프로그래머스

프로그래머스 JadenCase 문자열 만들기 파이썬(python)

hwajae 2023. 5. 6. 23:36
반응형

문제

JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해 주세요.

제한 사항

  • s는 길이 1 이상 200 이하인 문자열입니다.
  • s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
  • 숫자는 단어의 첫 문자로만 나옵니다.
  • 숫자로만 이루어진 단어는 없습니다.
  • 공백문자가 연속해서 나올 수 있습니다.

풀이

  1. 처음 받은 문자열 s를 split(" ") 이용하여 " " 단위로 쪼개준다. 띄어쓰기가 한 칸 이상인 구간도 있기 때문에 " " 명시해줘야 한다. 예를 들어 "a()()()b()()()()c" 라는 문자열을 쪼개면 -> ['a', '', '', 'b', ''b, '', '', '', 'c']가 된다. () 공백 한 칸 의미
  2. for문을 통해 쪼개진 문자들을 하나씩 탐색을 시작한다.
  3. word가 빈칸이 아니라면 첫 글자는 upper로 대문자 나머진 lower로 소문자로 변경해 준다.
  4. 빈칸인 경우는 그대로 다시 집어넣어준다.
  5. 마지막 answer리스트를 join 함수를 이용해 값들 사이에 " " 공백을 한 칸 집어넣어 문자열로 출력해 준다.
  6. 아래 코드에서 한 줄 코드는 위 과정을 한 줄로 나타낸 것이다. 작동하는 결과는 동일하다.

문제를 풀 다 런타임이 나시는 분들은 공백처리를 하지 않았기 때문인 거 같다. 

def solution(s):
    return " ".join([word[0].upper() + word[1:].lower() if word else word for word in s.split(" ")])
    
#----------------------------------------------------
def solution(s):
    answer = []
    s = s.split(" ")
    for word in s:
        if word:
            answer.append(word[0].upper() + word[1:].lower())
        else:
            answer.append(word)
    return " ".join(answer)

출처 : https://school.programmers.co.kr/learn/courses/30/lessons/12951

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

반응형