관리 메뉴

오늘도 배운다

신규 아이디 추천 / 프로그래머스, 파이썬 코딩테스트 연습2021 KAKAO BLIND RECRUITMENT 본문

코딩테스트연습(파이썬)

신규 아이디 추천 / 프로그래머스, 파이썬 코딩테스트 연습2021 KAKAO BLIND RECRUITMENT

LearnerToRunner 2022. 11. 18. 15:22

문제

신규 유저가 입력한 아이디를 나타내는 new_id가 매개변수로 주어질 때, "네오"가 설계한 7단계의 처리 과정을 거친 후의 추천 아이디를 return 하도록 solution 함수를 완성해 주세요.

 

[제한사항]
new_id는 길이 1 이상 1,000 이하인 문자열입니다.
new_id는 알파벳 대문자, 알파벳 소문자, 숫자, 특수문자로 구성되어 있습니다.
new_id에 나타날 수 있는 특수문자는 -_.~!@#$%^&*()=+[{]}:?,<>/ 로 한정됩니다.

 

 

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):
    # STEP 1
    new_id = new_id.lower()
    
    # STEP 2
    # 유효한 문자의 아스키코드 범위 만들기
    range_lower = list(range(ord('a'), ord('z')+1)) # a-z
    range_num = list(range(ord('0'), ord('9')+1)) # 0-9
    range_chr = list([ord('-'), ord('_'), ord('.')]) #-/_/.
    
    range_valid = range_lower + range_num + range_chr
    
    # 드랍 할 글자 리스트 만들기
    letter_drop = [letter for letter in new_id if ord(letter) not in range_valid]
    
    # 드랍
    for letter_to_drop in letter_drop:
        new_id = new_id.replace(letter_to_drop, "")
    
    # STEP 3
    count_dot = new_id.count(".")
    while(count_dot>1):
        dots = "."*count_dot
        if new_id.find(dots) != (-1):     
            new_id = new_id.replace(dots, ".")
        count_dot-=1
    
    # STEP 4
    new_id = new_id.strip(".") if new_id != "" else 'a'*len(new_id)
    
    # STEP 5
    new_id = 'a' if new_id == '' else new_id

    # STEP 6
    new_id = new_id[:15].rstrip(".") if len(new_id)>=16 else new_id
    
    # STEP 7
    print(f"new_id[::-1] = {new_id[-1]}")
    new_id = new_id+new_id[-1]*(3-len(new_id)) if len(new_id)<=2 else new_id
    
    
    answer = new_id
    
    return answer

 

 

제출 후 개선답안

 

 

다른 사람 코드를 통해
isalpha(), isdigit()을 알게됨 > Step 2 적용

'..........'  도 replace('..', '.')를 무한반복하더라도 '.'의 결과가 나옴 > Step 3 적용
find 함수 대신 in 함수를 적용 가능 > Step 3 적용

def solution(new_id):
    # STEP 1
    new_id = new_id.lower()
    
    answer = ''
    # STEP 2
    for letter in new_id:
        answer += letter if letter.isalpha() or letter.isdigit() or letter in ['-', '_', '.'] else ''
    
    # STEP 3
    while('..' in answer):
        answer = answer.replace('..', '.')
          
    # STEP 4
    answer = answer.strip('.')
    
    # STEP 5
    answer = 'a' if answer == '' else answer

    # STEP 6
    answer = answer[:15].rstrip(".") if len(answer)>=16 else answer
    
    # STEP 7
    len_a = len(answer)
    answer = answer+answer[-1]*(3-len_a) if len_a<=2 else answer
    
    
    return answer

 

 

 

 

문제 바로가기

 

728x90
Comments