[프로그래머스] Lv1 신규 아이디 추천

do yeon kim·2022년 9월 20일
0
회고

문제풀이를 완료 후 다른사람의 코드를 보았다.
내가 구현 한 코드는 각 조건을 반복문이나 조건문을 이용해서 풀었다면, 다른 풀이는 정규식을 이용해서 문제에 접근했다.

다른 풀이를 보고나서야 왜 정규식을 사용할 생각을 못했는지 나 자신에 화가났다.

이런 문제의 경우 바로 정규식을 떠올려서 문제풀이를 들어가는 것이 맞는데, 문제풀이의 경우의 수 중 정규식은 생각치도 못했따.

문제풀이에 정답이 없어서 어떻게든 풀 수 있겠지만, 이런 문제의 경우는 이렇게 접근하고, 이런문제의 경우는 또 이렇게 접근한다는 식의 모범적인 답안은 있을 수 있다.

꼭 똑같이 문제풀이를 할 필요는 없지만 일반적인 경우 이런식으로 풀 수 있다는 것도 고려해 두어야 된다는 생각이 든다.



풀이

https://school.programmers.co.kr/learn/courses/30/lessons/72410

# 1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
# 2단계 new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
# 3단계 new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
# 4단계 new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
# 5단계 new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
# 6단계 new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
#      만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
# 7단계 new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.


def solution(new_id):
    test = "~!@#$%^&*()=+[{]}:?,<>/"
    # 1단계
    new_id = new_id.lower()

    # 2단계
    new_id = "".join([i for i in new_id if i not in test])

    
    # 3단계
    temp = []
    stack = []
    stack.append(new_id[0])
    for i in range(1, len(new_id)):
        if stack[0] == "." and new_id[i] == ".":
            continue
        temp.append(stack.pop())
        stack.append(new_id[i])
    temp.append(stack.pop())
    new_id = "".join(temp)
    
    # 4단계
    while True:
        if len(new_id) == 1 and new_id[0] == ".":
            new_id = ""
            break
        
        if new_id[0] == ".":
            new_id = new_id[1:]
        
        if new_id[-1] == ".":
            new_id = new_id[:len(new_id)-1]
        

        if new_id[0] != "." and new_id[-1] != ".":
            break
    
   
    # 5단계
    if new_id == "":
        new_id = "a" 
    

    # 6단계
    if len(new_id) >= 16:
        new_id = new_id[0:15]

        if new_id[-1] == ".":
            new_id = new_id[:len(new_id)-1]  
  
    # 7단계
    if len(new_id) < 3:
        while len(new_id) < 3:
            new_id += new_id[-1]
    
    return new_id


정규식을 이용한 풀이
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

0개의 댓글