02-07 17:50
Notice
Recent Posts
Recent Comments
Link
«   2025/02   »
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28
Archives
관리 메뉴

기록을 합시다.

[프로그래머스] Jaden Case 본문

공부/알고리즘

[프로그래머스] Jaden Case

울집고양이세마리 2023. 4. 7. 21:47

문제 설명 

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

 

제한 조건

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

 

나의 풀이

아무튼 이 문제의 관건은 공백의 수 고려, 입력 문자열을 처음에는 lower case로 바꿔주는 것이다. 

def solution(s):
    lower_s = s.lower()

    nums = '1234567890'
    alph = 'abcdefghijklmnopqrstuvwxyz'
    
    new_s = []
    
    prev_char = ' '
    
    for char in lower_s:
        if char == ' ':
            new_s.append(char)
            prev_char = ' '
            continue
        
        if prev_char == ' ' :
            if char in alph:
                new_s.append(char.upper())
                prev_char = char 
            elif char in nums:
                new_s.append(char)
                prev_char = char 
            
            else:
                new_s.append(' ')
        else:
            new_s.append(char)
            prev_char = char 
        
    return ''.join(new_s)

나는 공백 문자, 즉 ' '를 기준으로 단어의 첫 글자를 구분하여 문제를 풀었다. 

솔직히 나도 이렇게 복잡하게 풀고싶지 않았다. 

 

원래 파이썬에서는 공백 기준으로 split하면 공백도 함께 리스트 안에 담기는 것으로 알고있다. 

"Hello World".split(" ")
#결과 : ["Hello", " ", "World"]

그런데 아무리 이렇게 하려고 해도 되지 않았다.

내 지식이 잘못 되었는가 해서 인터넷에 검색해보아도 이렇게 풀고 있는 사람들이 많았다. 

도대체 왜 안 되는지 검색해봐도 내용은 나오지 않았고 지금도 현재 미궁에 빠져있다.. 

 

저렇게 되기만 한다면 짧게 코드를 썼을 것인데 그렇지 않고 이전 캐릭터를 변수에 담아놔서 " "가 있는지 없는지를 일일이 구분해서 풀었다. 심지어 이 문제에서는 공백이 한꺼번에 여러 개 나올 수가 있다. 마치 "    " 이런 것처럼.. 그래서 공백의 크기도 고려해야 하는 문제였기에 어쩔 수 없이 ㅜㅜ.. (자꾸 변명만 나오네)

 

 

 

Comments