Programmers Level.1 Question Review ✏️
문제출처: https://programmers.co.kr/learn/courses/30/lessons/72410
- 1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
- 2단계 newid에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(), 마침표(.)를 제외한 모든 문자를 제거합니다.
- 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이 될 때까지 반복해서 끝에 붙입니다.
function solution(new_id) {
//1단계, 2단계
new_id = new_id.toLowerCase().replace(/[^a-z\d\-\_\.]/g, "");
//3단계
new_id = new_id.replace(/\.+\./g, '.');
//4단계 - / 는 or을 나타냄
new_id = new_id.replace(/^\.|\.$/g, "");
//5단계
if(new_id === '') new_id = "a";
//6단계
if(new_id.length >= 16) {
//ew_id = new_id.replace(/a-z/g, "")
new_id = new_id.slice(0, 15).replace(/\.$/g, '');
//7단계
}
if(new_id.length <= 2) {
const lastLetter = new_id[new_id.length - 1];
const requiredCount = 3 - new_id.length;
for(let i = 0; i < requiredCount; i++){
new_id += lastLetter;
}
}
return new_id;
}
[]
) 안의 조건을 찾는다. (a-z
는 문자열,d
는 숫자 찾기)^
)을 쓰면 !
를 사용하는 것과 같이 불일치조건을 반환하게 된다. ^
)의 또 다른 의미는 가장 첫번째 자리가 된다. 즉, ^\.
은 가장 첫번째 자리에 .
가 있는 지를 확인하는 것. $
는 마지막 자리를 체크. 즉, \.$
는 마지막 자리에 .
가 있는 지를 확인하는 것. |
는 OR 연산자의 역할. +
를 사용해서 연속되는 문자를 검색할 수 있다. \s
는 공백을 의미한다.{최소, 최대}
로 표현된다. 예)\.{3,}
은 .
이 3개 이상 (연속해서)오는 경우 전부를 검색. \.{3, 6}
은 .
이 3개 이상 6개 이하로 오는 경우 전부를 검색.