Notice
Recent Posts
Recent Comments
Link
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | |||
| 5 | 6 | 7 | 8 | 9 | 10 | 11 |
| 12 | 13 | 14 | 15 | 16 | 17 | 18 |
| 19 | 20 | 21 | 22 | 23 | 24 | 25 |
| 26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 신경쓰기의 기술
- 피그마인디언
- TensorFlowGPU
- 코딩테스트
- 당신의 인생이 왜 힘들지 않아야 한다고 생각하십니까
- 파이썬
- Labor Management System
- 딥러닝
- 데이터분석
- 코딩테스트연습
- HackerRank
- 웨어하우스 보관 최적화
- oracle
- ABC Analysis
- MS SQL Server
- pandas profiling
- Inventory Optimization
- eda
- ModelCheckPoint
- kaggle
- MySQL
- ProfileReport
- leetcode
- SKU Consolidation
- tensorflow
- Product Demand
- forecast
- Gaimification
- SQL
- 프로그래머스
Archives
- Today
- Total
오늘도 배운다
신규 아이디 추천 / 프로그래머스, 파이썬 코딩테스트 연습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
'코딩테스트연습(파이썬)' 카테고리의 다른 글
| 평균 구하기 / 프로그래머스, 파이썬 코딩테스트 연습 연습문제 (0) | 2022.11.21 |
|---|---|
| 정수 제곱근 판별 / 프로그래머스, 파이썬 코딩테스트 연습 연습문제 (0) | 2022.11.21 |
| 하샤드 수 / 프로그래머스, 파이썬 코딩테스트 연습 연습문제 (0) | 2022.11.21 |
| 모음 제거 / 프로그래머스, 파이썬 코딩테스트 연습코딩테스트 입문 (0) | 2022.11.21 |
| A로 B 만들기 / 프로그래머스, 파이썬 코딩테스트 연습코딩테스트 입문 (0) | 2022.11.18 |
Comments