Notice
Recent Posts
Recent Comments
Tags
- 알고리즘 문제
- Spring 초보
- Django 기초
- 스프링 기초
- 코딩테스트 연습
- 백준 선수과목 14567
- 백준 선수과목 파이썬
- 백준 14567
- 스프링 초보
- 프로그래머스
- 코테 연습
- 백준 다이나믹프로그래밍
- programmers
- 백준 dp
- 백준 선수과목 python
- 코테
- spring 기초
- 백준 14567 python
- 알고리즘 공부
- 위상정렬 파이썬
- 코딩테스트
- 프로그래머스 레벨1
- 백준
- dp 알고리즘
- 프로그래머스 level1
- 백준 14567 파이썬
- 장고
- Django
- 장고 기초
- 백준 선수과목
Archives
- Today
- Total
일일구름 IT
프로그래머스 lv.1 [신규 아이디 추천] 2021 KAKAO BLIND RECRUITMENT 본문
문제 설명
다음은 카카오 아이디의 규칙입니다.
- 아이디의 길이는 3자 이상 15자 이하여야 합니다.
- 아이디는 알파벳 소문자, 숫자, 빼기(``), 밑줄(_), 마침표(.) 문자만 사용할 수 있습니다.
- 단, 마침표(.)는 처음과 끝에 사용할 수 없으며 또한 연속으로 사용할 수 없습니다.
더보기
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):
answer = ''
# 1단계
new_id = new_id.lower()
print(new_id)
# 2단계
characters = """`~!@#$%^&*()+={}[]|\:;"'<>,?/"""
new_id = ''.join(x for x in new_id if x not in characters)
print(new_id)
# 3단계
while ".." in new_id:
new_id = new_id.replace('..', '.')
print(new_id)
# 4단계
new_id = new_id.strip(".")
print(new_id)
# 5단계
if new_id == '': new_id = 'a'
print(new_id)
# 6단계
while len(new_id) >= 16: new_id = new_id[0:15]
print(new_id)
# 7단계
if len(new_id) <= 2: new_id = new_id.ljust(3, new_id[-1])
print(new_id)
return answer
new_id = "=.="
#new_id = "z-+.^."
#new_id = "...!@BaT#*..y.abcdefghijklm"
solution(new_id)
- .lower()
- ‘’.join()
- .replace()
- .lstrip()
- 슬라이싱을 이용해 15문자 뒤의 문자는 제거
- .ljust() 를 이용해 크기가 3이고 new_id[-1]로 오른쪽을 채운 문자열 만듦
다른 사람 풀이:
import re
def solution(new_id):
st = new_id
st = st.lower()
st = re.sub('[^a-z0-9\-_.]', '', st)
st = re.sub('\.+', '.', st)
st = re.sub('^[.]|[.]$', '', st)
st = 'a' if len(st) == 0 else st[:15]
st = re.sub('^[.]|[.]$', '', st)
st = st if len(st) > 2 else st + "".join([st[-1] for i in range(3-len(st))])
return st
- 정규 표현식 : https://wikidocs.net/4308
- re.sub('[^a-z0-9\-_.]', '', st) → 소문자, 숫자, -, _, .를 제외한 문자 제거
- ^ : not
- : 두 문자 사이의 범위
- ^ : not
- re.sub('\.+', '.', st) → 연속된 ‘.’를 ‘.’으로 바꿈
-
- : + 앞에 있는 문자를 1이상 무한으로 반복
-
for c in new_id:
if c.isalpha() or c.isdigit() or c in ['-', '_', '.']:
answer += c
- .isalpha() : 알파벳인지 검사
- isdigit() : 숫자인지 검사
구글링한 부분:
- .upper → 대문자로 변환
- .lower → 소문자로 변환
- ‘’.join() : ‘[구분자]’.join([리스트]) 리스트 문자열로 합치기
- .replace([바뀔 문자], [넣을 문자열])
- startwith([특정 문자], [시작 지점]) : 특정 문자로 시작하는지 검사
- endswith([특정 문자], [시작 지점], [끝 지점]) : 특정 문자로 끝나는지 검사
- strip([문자열]) : 특정 문자열이 문자열의 양쪽에 있으면 제거
- lstrip([문자열]) : 특정 문자열이 문자열의 왼쪽에 있으면 제거
- rstrip([문자열]) : 특정 문자열이 문자열의 오른쪽에 있으면 제거
- ljust([칸 수], [채우고 싶은 문자열]) : 칸 수를 정하고 왼쪽으로 정렬 후 빈칸을 문자열로 채움
- rjust([칸 수], [채우고 싶은 문자열]) : 칸 수를 정하고 오른쪽으로 정렬 후 빈칸을 문자열로 채움
https://loud-scorpion-36f.notion.site/d1480d49b72249a4bff0765088bd5d5b
'프로그래머스 > 프로그래머스 lv.1' 카테고리의 다른 글
프로그래머스 lv.1 [크레인 인형 뽑기] 2019 카카오 개발자 겨울 인턴십 게임 (0) | 2022.07.06 |
---|---|
프로그래머스 lv.1 [키패드 누르기] 2020 카카오 인턴십 (0) | 2022.07.06 |
프로그래머스 lv.1 [숫자 문자열과 영단어] 2021 카카오 채용연계형 인턴십 (0) | 2022.07.06 |
프로그래머스 lv.1 [로또의 최고 순위와 최저 순위] 2021 Dev-Matching: 웹 백엔드 개발자 (0) | 2022.07.05 |
프로그래머스 lv.1 [신고 결과 받기] 2022 KAKAO BLIND RECRUITMENT (0) | 2022.07.05 |