[프로그래머스] 신규 아이디 추천 (자바스크립트/js/javascript)
2021. 6. 22. 16:44ㆍFront-end/알고리즘
728x90
반응형
문제 출처: https://programmers.co.kr/learn/courses/30/lessons/72410
function solution(new_id) {
let answer = new_id;
// 1단계: new_id의 모든 대문자를 대응되는 소문자로 치환
answer = answer.toLowerCase();
// 2단계: new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거
answer = answer.replace(/[^a-z0-9-_.]/g, "");
// 3단계: new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환
answer = answer.replace(/\.{2,}/g, ".");
// 4단계: new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
answer = answer.replace(/(^\.|\.$)/g, "");
// 5단계: new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
if (answer === "") {
answer = "a";
}
// 6단계: new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
//만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거
if (answer.length >= 16) {
answer = answer.substring(0, 15);
}
if (answer[answer.length - 1] === ".") {
answer = answer.substring(0, 14);
}
//7단계: new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다
if (answer.length <= 2) {
const lastChar = answer.charAt(answer.length - 1);
const length = answer.length;
for (let i = 0; i < 3 - length; i++) {
answer = answer.concat(lastChar);
}
}
return answer;
}
정규표현식을 통해 풀 수 있는 문제이다.
자바스크립트에는 replaceAll이 없기 때문에 정규표현식을 통해서 사용하면 된다. 이 때 정규표현식의 플래그는 /g여야 일치하는 모든 것이 replace 메소드를 통해 대체된다.
728x90
반응형
'Front-end > 알고리즘' 카테고리의 다른 글
[프로그래머스] 키패드 누르기 (자바스크립트/javascript/js) (0) | 2021.06.22 |
---|---|
[프로그래머스] 로또의 최고순위와 최저순위 (0) | 2021.06.22 |
[프로그래머스] 메뉴 리뉴얼 (0) | 2021.06.22 |
[백준] 1697. 숨바꼭질 (자바스크립트/js/javascript/node.js/BFS) (0) | 2021.06.07 |
[백준] 7569. 토마토 (자바스크립트/javascript/js/node.js/BFS/알고리즘) (0) | 2021.06.04 |