
주소: https://programmers.co.kr/learn/courses/30/lessons/72410
[ 문제 ]

[ 나의 귀여운 풀이 ]
def step1(new_id): # 1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
new_id = new_id.lower()
return new_id
def step2(new_id): # 2단계 new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
li = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '-', '_', '.', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i',
'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
for i in range(len(new_id)):
if new_id[i] not in li:
new_id = new_id.replace(new_id[i], ' ')
new_id = new_id.replace(' ', '')
return new_id
def step3(new_id): # 3단계 new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
new_id = list(new_id)
str = ''
for i in range(len(new_id)-1):
if new_id[i] == '.' and new_id[i+1] == '.':
str += ' '
else:
str += new_id[i]
str += new_id[-1]
str = str.replace(' ', '')
return str
def step4(new_id): # 4단계 new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
if new_id == '.':
return ''
if new_id[0] == '.':
new_id = new_id[1:]
if new_id[len(new_id)-1] == '.':
new_id = new_id[:len(new_id)-1]
return new_id
def step5(new_id): # 5단계 new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
if len(new_id) == 0:
new_id += 'a'
return new_id
def step6(new_id): # 6단계 new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다. # 만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
if len(new_id) >= 16:
new_id = new_id[:15]
new_id = step4(new_id)
return new_id
def step7(new_id): # 7단계 new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.
if len(new_id) <= 2:
ch = new_id[-1]
while len(new_id) <= 2:
new_id += ch
return new_id
def preliminary(new_id):
new_id = step1(new_id)
new_id = step2(new_id)
new_id = step3(new_id)
new_id = step4(new_id)
new_id = step5(new_id)
new_id = step6(new_id)
new_id = step7(new_id)
return new_id
def solution(new_id):
answer = ''
answer += preliminary(new_id)
return answer
[ 다른 분들의 유려한 코드 ]
- step2()
def step2(new_id): # 2단계 new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
result = ""
for c in new_id:
# 알파벳이 아니고, -_.이 아니면 패스 나머지는 추가
if ((not c.isalnum()) and (c != "-" and c != "_" and c != ".")):
pass
else:
result += c
return result
step2 - 소문자, 숫자, -, _, . 를 제외한 문자를 제거하는 단계다. str.isalnum() 메소드는 string이 alphabet, number인지 판별 후 True, False 반환하는 메소드다. 대문자는 step1에서 걸러주기 때문에 이 메소드를 사용하는 것이 이 step에서 출제자들이 원하는 답이 아니었을까? 하는 생각이 들었다...
- step3()
# 3
while '..' in answer:
answer = answer.replace('..', '.')
다른 분의 step3 코드...
def step3(new_id): # 3단계 new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
new_id = list(new_id)
str = ''
for i in range(len(new_id)-1):
if new_id[i] == '.' and new_id[i+1] == '.':
str += ' '
else:
str += new_id[i]
str += new_id[-1]
str = str.replace(' ', '')
return str
처음에는 다른 분의 코드처럼 '..'이 문자열 내에 있을 경우 while문을 돌려, replace하는 발상은 같이 했으나... find함수로는 구현하지 못해서 돌아가는 길을 선택했는데... 구현만 해낼 수 있었다면 정말 깔끔한 코드를 짰을 것 같아 아쉬운 부분이다. 이러면서 배우는거지~ ㅎㅎ
- 정규표현식을 사용한 코드(문자열 관련 문제를 볼 때마다 정규표현식을 공부해야겠다고 생각이 많이 든다...)
import re
def solution(new_id):
st = new_id
st = st.lower()
st = re.sub('[^a-z0-9\-_.]', '', st)
st = re.sub('\.+', '.', st)
st = re.sub('^[.]|[.]$', '', st)
st = 'a' if len(st) == 0 else st[:15]
st = re.sub('^[.]|[.]$', '', st)
st = st if len(st) > 2 else st + "".join([st[-1] for i in range(3-len(st))])
return st
정규표현식을 사용하니... 이렇게도 간결한 코드가 가능하다...
[ 배운 것 ]
1. string 관련 메소드: https://dojang.io/mod/page/view.php?id=2299
2. 정규표현식(공부하자): https://wikidocs.net/4308
꾸준히 열심히!
'Otter's [ 개발새발 ] > # 코딩테스트 - Programmers' 카테고리의 다른 글
| [Programmers 코딩테스트 연습_Lv1_Python] 내적 (0) | 2022.06.03 |
|---|---|
| [Programmers 코딩테스트 연습_Lv1_Python] [카카오 인턴] 키패드 누르기 (0) | 2022.06.03 |
| [Programmers 코딩테스트 연습_Lv1_Python] 숫자 문자열과 영단어 (0) | 2022.06.03 |
| [Programmers 코딩테스트 연습_Lv1_Python] 로또의 최고 순위와 최저 순위 (0) | 2022.05.31 |
| [Programmers 코딩테스트 연습_Lv1_Python] 신고 결과 받기 (0) | 2022.05.30 |