프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
나의 답
[instruction]
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이 될 때까지 반복해서 끝에 붙입니다.
function solution(new_id) {
let answer = [];
// 1단계
let temp = [...new_id.toLowerCase()];
// 2단계
const alpha = "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 - _ .";
temp = temp.filter((e) => {
if (alpha.includes(e)) return e;
else if (!alpha.includes(e) && !isNaN(parseInt(e))) return e;
});
//3단계 - forEach를 사용하면 안됨... 가운데 ..이 안 지워짐..ㅠㅠ
answer = temp.filter((e, i) => {
if (e !== ".") {
return true;
} else if (e === "." && temp[i + 1] === ".") {
return false;
} else return true;
});
//4단계
function deleteDote(answer) {
if (answer[0] === ".") answer.splice(0, 1);
if (answer[answer.length - 1] === ".") answer.splice(answer.length - 1, 1);
return answer;
}
deleteDote(answer);
// 5단계
if (!answer.join()) {
answer.push("a");
}
// 6단계 -> 4단계에서 구현한 deleteDote()함수 재사용
if (answer.length > 15) {
answer.splice(15, answer.length - 15);
deleteDote(answer);
}
// 7단계
if (answer.length <= 2) {
while (answer.length < 3) {
answer.push(answer[answer.length - 1]);
}
}
return answer.join("");
}
console.log(solution("...!@BaT#*..y.abcdefghijklm"));
console.log(solution(""));
console.log(solution("a"));
이 문제는 무식하게 한 줄 한 줄 구현해봄..ㅋㅋ
시간 있을 때 다시 보면서 깔끔하게 줄여보면 좋을 것 같음..!
'항해99_10기 > [2주차] 알고리즘 문제풀이' 카테고리의 다른 글
| [25번][중급] 약수의 개수와 덧셈 (0) | 2022.11.23 |
|---|---|
| [23번][중급] 시저암호 (0) | 2022.11.23 |
| [23번][중급] 시저암호 (0) | 2022.11.23 |
| [22번] [중급] 숫자 문자열과 영단어 (0) | 2022.11.23 |
| [31번][중급] 소수 찾기 (0) | 2022.11.23 |