반응형
문제
https://school.programmers.co.kr/learn/courses/30/lessons/72410
문제 풀이
정규표현식은 실제 시험볼 때 기억이 안날 것 같아서,, 최대한 문자열 처리함수로 풀이함.
정규표현식 중 r'\.+'는 .가 연속적으로 여러개 나오는 것을 모두 처리하는 패턴임.
코드
import re
def solution(new_id):
new_id = new_id.lower()
new_id = ''.join([i if 'a'<=i<='z' or '0'<=i<='9' or i in ['-','_','.'] else '' for i in new_id])
new_id = re.sub(r'\.+', '.', new_id)
new_id = new_id.strip('.')
new_id = 'a' if not new_id else new_id
new_id = new_id[:15].strip('.')
new_id += new_id[-1] * max(0, 3-len(new_id))
return new_id
반응형
'알고리즘 > 프로그래머스 문제풀이' 카테고리의 다른 글
[프로그래머스] lv.1 바탕화면 정리 python 풀이 (0) | 2023.10.31 |
---|---|
[프로그래머스] lv.1 짝수와 홀수 python 풀이 (0) | 2023.10.31 |
[프로그래머스] lv.1 이상한 문자 만들기 python 풀이 (0) | 2023.10.30 |
[프로그래머스] lv.1 공원 산책 python 풀이 (0) | 2023.10.29 |
[프로그래머스] lv.1 강원도에 위치한 생산공장 목록 출력하기 sql 풀이 (0) | 2023.10.29 |