JadenCase 문자열 만들기
문제 설명
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.
- s는 길이 1 이상 200 이하인 문자열입니다.
- s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
- 숫자는 단어의 첫 문자로만 나옵니다.
- 숫자로만 이루어진 단어는 없습니다.
- 공백문자가 연속해서 나올 수 있습니다.
"3people unFollowed me" | "3people Unfollowed Me" |
"for the last week" | "For The Last Week" |
내 풀이
def solution(s):
answer = []
ss = s.lower().split(" ")
for s in ss:
if s != "":
s = list(s)
s[0] = s[0].upper()
s = ''.join(s)
answer.append(s)
return ' '.join(answer)
맨 앞에 공백이 있을 경우를 고려해야한다.
- split(" ")로 공백을 기준으로 split() 한다.
- split()으로 하면 연속된 공백을 기준으로 나누는데, split(" ")으로 하면 단일 공백을 기준으로 나눈다.
- 이를 통해 맨 앞의 공백을 나타낼 수 있다.
s.lower()를 하고 시작하여, 모든 문자를 소문자로 만들고 시작한다. 그리고 for문을 돌면서 s가 문자일 경우에는 첫글자를 대문자로 바꾼다.
def solution(s):
answer = []
ss = s.lower().split(" ")
for s in ss:
if s != "":
s = s.capitalize()
answer.append(s)
return ' '.join(answer)
이렇게 if문 안에서 첫글자만 대문자로 바꾸는 것을 capitalize() 함수로 대체할 수 있다.
728x90
'파이썬 알고리즘 문제 풀이' 카테고리의 다른 글
[프로그래머스] Lv2. 무인도 여행 / BFS, DFS (3) | 2024.09.13 |
---|---|
[프로그래머스] Lv2. 짝지어 제거하기 (0) | 2024.09.13 |
[프로그래머스] Lv2. 리코쳇 로봇 / BFS (0) | 2024.09.11 |
[프로그래머스] Lv2. 다리를 지나는 트럭 (0) | 2024.09.09 |
[프로그래머스] Lv2. 호텔 대실 (0) | 2024.09.07 |