[프로그래머스] 신규 아이디 추천 문제 풀이 python

mauz·2022년 5월 16일
0

🐒 신규 아이디 추천

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

✍ 나의 풀이

def solution(new_id):
	#1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
    answer = new_id.lower()
	
    #2단계 new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
    idx = 0
    while True:
        if 'a' <= answer[idx] <= 'z' or '0' <= answer[idx] <= '9' or answer[idx] in ['-','_','.']:
            idx += 1
        else:
            answer = answer.replace(answer[idx],'')
        if idx == len(answer):
            break
            
    #3단계 new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
    while '..' in answer:
        answer = answer.replace('..','.')
	
    #4단계 new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
    if answer and answer[0] == '.':
        answer = answer[1:]
    if answer and answer[-1] == '.':
        answer = answer[:-1]
        
    #5단계 new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
    if not answer:
        answer = 'a'
        
    #6단계 new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
    answer = answer[:15]
    # 만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
    if answer[-1] == '.':
        answer = answer[:14]
        
    #7단계 new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.
    if len(answer) < 3:
        answer += answer[-1]*(3-len(answer))

    return answer
5단계 new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.

를 원본 문자열만큼 a를 추가하라는 말로 잘못 이해해서 못풀고있다가
단순히 a 하나만 대입한다는 걸 깨달았다.

좀 난잡하게 코드를 짰다. 다른 사람들 답안을 보니 정규 표현식으로 짧게 나타낸 분들도 있었지만
나랑 비슷한 개념으로 좀더 간결하게 작성하신 분 들도 있었다.


🔍 다른 답안

def solution(new_id):
    answer = ''
    # 1
    new_id = new_id.lower()
    # 2
    for c in new_id:
        if c.isalpha() or c.isdigit() or c in ['-', '_', '.']:
            answer += c
    # 3
    while '..' in answer:
        answer = answer.replace('..', '.')
    # 4
    if answer[0] == '.':
        answer = answer[1:] if len(answer) > 1 else '.'
    if answer[-1] == '.':
        answer = answer[:-1]
    # 5
    if answer == '':
        answer = 'a'
    # 6
    if len(answer) > 15:
        answer = answer[:15]
        if answer[-1] == '.':
            answer = answer[:-1]
    # 7
    while len(answer) < 3:
        answer += answer[-1]
    return answer

출처


🧠 문제 이해

2단계 newid에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(), 마침표(.)를 제외한 모든 문자를 제거합니다.

idx = 0
while True:
	if 'a' <= answer[idx] <= 'z' or '0' <= answer[idx] <= '9' or answer[idx] in ['-','_','.']:
    	idx += 1
    else:
    	answer = answer.replace(answer[idx],'')
    if idx == len(answer):
		break

위 코드를 바꾸면

for c in new_id:
        if c.isalpha() or c.isdigit() or c in ['-', '_', '.']:
            answer += c

문자열속 문자가 알파벳과 숫자인지를 확인하는 방법으로
isalpha(), isdigit() 메소드를 이용해 불리언을 받아올 수 있다.

#3단계 new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.

while '..' in answer:
	answer = answer.replace('..','.')

반복해서 ..가 있는지 확인해 ..를 .로 바꾼다.

#7단계 new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.

while len(answer) < 3:
        answer += answer[-1]

길이가 3이하 일 동안 마지막 문자를 추가한다.


profile
쥐구멍에 볕드는 날

0개의 댓글