문제
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
정답
function solution(new_id) {
// 1단계: new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
new_id = new_id.toLowerCase();
// 2단계: new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
const filterText = [
"a",
"b",
"c",
"d",
"e",
"f",
"g",
"h",
"i",
"j",
"k",
"l",
"m",
"n",
"o",
"p",
"q",
"r",
"s",
"t",
"u",
"v",
"w",
"x",
"y",
"z",
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"0",
"-",
"_",
".",
];
new_id = new_id
.split("")
.filter(text => filterText.includes(text))
.join("");
// 3단계: new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
while (true) {
if (new_id.includes("..")) {
new_id = new_id.replace("..", ".");
} else {
break;
}
}
// 4단계: new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
new_id = new_id.split("");
if (new_id[0] === ".") {
new_id[0] = "";
} else if (new_id[new_id.length - 1] === ".") {
new_id[new_id.length - 1] = "";
}
new_id = new_id.join("");
// 5단계: new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
if (new_id === "") {
new_id = "a";
}
// 6단계: new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
// 만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
new_id = new_id.split("");
if (new_id.length >= 16) {
new_id = new_id.slice(0, 15);
}
if (new_id[new_id.length - 1] === ".") {
new_id = new_id.slice(0, new_id.length - 1);
}
new_id = new_id.join("");
// 7단계: new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.
if (new_id.length <= 2) {
while (true) {
if (new_id.length > 2) {
break;
} else {
new_id += new_id[new_id.length - 1];
}
}
}
return new_id;
}