새소식

자료구조&알고리즘

PRO#12951 : JadenCase 문자열 만들기

  • -

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

'자료구조&알고리즘' 카테고리의 다른 글

PRO#12936 : 줄 서는 방법  (0) 2022.08.18
PRO#42890 : 후보키  (0) 2022.08.18
PRO#42860 : 조이스틱  (0) 2022.08.03
PRO#60057 : 문자열 압축  (0) 2022.08.01
PRO#42746 : 가장 큰 수  (0) 2022.07.31
Contents