본문 바로가기

항해99_10기/[2주차] 알고리즘 문제풀이

[24번][중급] 신규 아이디 추천

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

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"));

 

이 문제는 무식하게 한 줄 한 줄 구현해봄..ㅋㅋ

시간 있을 때 다시 보면서 깔끔하게 줄여보면 좋을 것 같음..!