기록을 합시다.
[프로그래머스] Jaden Case 본문
문제 설명
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"]
그런데 아무리 이렇게 하려고 해도 되지 않았다.
내 지식이 잘못 되었는가 해서 인터넷에 검색해보아도 이렇게 풀고 있는 사람들이 많았다.
도대체 왜 안 되는지 검색해봐도 내용은 나오지 않았고 지금도 현재 미궁에 빠져있다..
저렇게 되기만 한다면 짧게 코드를 썼을 것인데 그렇지 않고 이전 캐릭터를 변수에 담아놔서 " "가 있는지 없는지를 일일이 구분해서 풀었다. 심지어 이 문제에서는 공백이 한꺼번에 여러 개 나올 수가 있다. 마치 " " 이런 것처럼.. 그래서 공백의 크기도 고려해야 하는 문제였기에 어쩔 수 없이 ㅜㅜ.. (자꾸 변명만 나오네)
'공부 > 알고리즘' 카테고리의 다른 글
[프로그래머스] 완주하지 못 한 선수 (0) | 2023.06.11 |
---|---|
[프로그래머스] 최소 직사각형(python/java) (0) | 2023.06.11 |
[프로그래머스] k번째 수(python/java) (0) | 2023.06.05 |
[프로그래머스] 같은 숫자는 싫어(python/java) (0) | 2023.06.05 |
[프로그래머스] 폰켓몬(python/java) (0) | 2023.06.05 |