자료구조&알고리즘
PRO#12951 : JadenCase 문자열 만들기
StoneSeller
2022. 8. 8. 17:56
JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다. (첫 번째 입출력 예 참고)
문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요.
제한 조건
- s는 길이 1 이상 200 이하인 문자열입니다.
- s는 알파벳과 숫자, 공백문자(" ")로 이루어져 있습니다.
- 숫자는 단어의 첫 문자로만 나옵니다.
- 숫자로만 이루어진 단어는 없습니다.
- 공백문자가 연속해서 나올 수 있습니다.
입출력 예
Sol 1) 런타임 오류
def solution(s):
answer = ''
word_list = s.split(' ')
for i in range(len(word_list)):
if word_list[i][0].isalpha():
word_list[i] = word_list[i][0].upper() + word_list[i][1:].lower()
return ' '.join(word_list)
문자열을 체크할 때 길이가 0보다 큰지 검사하는 로직을 추가해주었다.
또한 3peoPle 같이 중간에 대문자가 존재할 수 도 있기 때문에 else 문을 추가하여 앞이 알파벳으로 시작하지 않아도 뒤에 문자들을 소문자로 바꾸어주도록 하였다.
def solution(s):
answer = ''
word_list = s.split(' ')
for i in range(len(word_list)):
if len(word_list[i]) != 0 and word_list[i][0].isalpha():
word_list[i] = word_list[i][0].upper() + word_list[i][1:].lower()
else:
word_list[i] = word_list[i].lower()
return ' '.join(word_list)
Sol 2) caplialize() 함수 사용
문자열의 첫글자는 대문자로, 나머지는 소문자로 변환하는 함수이다.
def solution(s):
answer = ''
word_list = s.split(' ')
for i in range(len(word_list)):
word_list[i] = word_list[i].capitalize()
return ' '.join(word_list)
728x90