본문 바로가기

두두의 알고리즘/문제

[탐욕법] 프로그래머스 L1 '신규 아이디 추천' (Python)

728x90

<문제 링크>

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

 

코딩테스트 연습 - 신규 아이디 추천

카카오에 입사한 신입 개발자 네오는 "카카오계정개발팀"에 배치되어, 카카오 서비스에 가입하는 유저들의 아이디를 생성하는 업무를 담당하게 되었습니다. "네오"에게 주어진 첫 업무는 새로

programmers.co.kr


<문제 풀이>

1. 문제에서 주어진 순서대로 코딩을 한다

 

<코드>

import re
def solution(new_id):
    answer = ''
    #1
    new_id = new_id.lower()
    
    #2
    prog = re.compile('[a-z0-9\.\-\_]')
    for i in new_id:
        if prog.match(i) == None:
            continue
        else:
            m = re.match('[a-z0-9\.\-\_]',i)
            answer += m.group(0)
    
    #3
    while '..' in answer:
        answer = answer.replace('..','.')
        
    #4
    if answer=='.':
        answer = ''
    else:
        if answer[0] == '.':
            answer = answer[1:]
        if answer[-1] == '.':
            answer = answer[:-1]
    
    #5
    if answer == '':
        answer = 'a' * 3
    
    #6
    if len(answer) >= 16:
        answer = answer[:15]
        while answer[-1] == '.':
            answer = answer[:-1]
    
    #7
    if len(answer) <= 2:
        while len(answer) < 3:
            answer += answer[-1]
            
    return answer

 

<고쳐야 할 점>

  • 5단계에서 new_id가 빈 문자열이라면, new_id에 a를 대입 == new_id에 a를 3개 대입. 아이디의 길이는 3자 이상이어야 하기 때문에
  • 복습 알고리즘