반응형
문제
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해 주세요.
제한 사항
- s는 길이 1 이상 200 이하인 문자열입니다.
- s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
- 숫자는 단어의 첫 문자로만 나옵니다.
- 숫자로만 이루어진 단어는 없습니다.
- 공백문자가 연속해서 나올 수 있습니다.
풀이
- 처음 받은 문자열 s를 split(" ") 이용하여 " " 단위로 쪼개준다. 띄어쓰기가 한 칸 이상인 구간도 있기 때문에 " " 명시해줘야 한다. 예를 들어 "a()()()b()()()()c" 라는 문자열을 쪼개면 -> ['a', '', '', 'b', ''b, '', '', '', 'c']가 된다. () 공백 한 칸 의미
- for문을 통해 쪼개진 문자들을 하나씩 탐색을 시작한다.
- word가 빈칸이 아니라면 첫 글자는 upper로 대문자 나머진 lower로 소문자로 변경해 준다.
- 빈칸인 경우는 그대로 다시 집어넣어준다.
- 마지막 answer리스트를 join 함수를 이용해 값들 사이에 " " 공백을 한 칸 집어넣어 문자열로 출력해 준다.
- 아래 코드에서 한 줄 코드는 위 과정을 한 줄로 나타낸 것이다. 작동하는 결과는 동일하다.
문제를 풀 다 런타임이 나시는 분들은 공백처리를 하지 않았기 때문인 거 같다.
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
반응형
'PS > 프로그래머스' 카테고리의 다른 글
프로그래머스 연속 부분 수열 합의 개수 파이썬(python) (1) | 2023.05.07 |
---|---|
프로그래머스 두 큐 합 같게 만들기 파이썬(python) (0) | 2023.05.05 |
프로그래머스 보석 쇼핑 파이썬(python) (0) | 2023.05.04 |
프로그래머스 네트워크 파이썬(python) (0) | 2023.05.03 |
프로그래머스 풍선 터트리기 파이썬(python) (0) | 2023.05.03 |