신규 아이디 추천

하이·2022년 4월 25일
0

💣 문제

  1. new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
  2. newid에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(), 마침표(.)를 제외한 모든 문자를 제거합니다.
  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이 될 때까지 반복해서 끝에 붙입니다.

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

💬 내 접근 방식

def solution(new_id):
    new_id = new_id.lower()
    new_arr = []
    for e in new_id:
        if e.isdigit() or e == '-' or e == '_' or e == '.' or e.isalpha():
            new_arr.append(e)

    new_arr2 = []
    is_dot = False
    for e in new_arr:
        if e != '.':
            is_dot = False
        if e == '.' and is_dot is True:
            continue
        if e == '.':
            is_dot = True
        new_arr2.append(e)

    if new_arr2 and new_arr2[0] == '.':
        new_arr2.pop(0)
    if new_arr2 and new_arr2[-1] == '.':
        new_arr2.pop(-1)
    if not new_arr2:
        new_arr2.append('a')
    if len(new_arr2) >= 16:
        new_arr2 = new_arr2[:15]
    if new_arr2[-1] == '.':
        new_arr2.pop(-1)
    while len(new_arr2) <= 2:
        new_arr2.append(new_arr2[-1])
    return ''.join(new_arr2)

간단하게 하라는대로만 한 풀이다.

💯 제출 후 확인한 풀이

  1. 정규식을 이용한 풀이
  2. 일반적인 풀이

위 두 가지 풀이가 가능했다. 나는 일반적인 풀이가 조금 더 마음에 들었다. 정규식을 쓰면 10줄이면 끝나는거 같았지만, 떨리는 코딩 테스트용으로는 일반적으로 쓰는 풀이가 맞다고 생각이 들었다.

차이점

  1. if 문 안에서 or 로 처리하지 않았다는 점
  2. 연속된 점을 찾는데 .. 와 같은 형태를 . 으로 계속 바꿔 처리했다는 점

이런 차이점이 있었는데 풀이에서 1번은 in [] 과 같은 꼴로 처리했다. 파이썬을 쓰다보면 익숙해지지 않을까 생각이 든다. 2번과 같은 생각을 하려면 조금 더 노력해야 될 거 같다.

profile
안녕하세요

0개의 댓글