티스토리 뷰

320x100

2021년 1월 25일 Velog에 작성한 글을 옮겨온 글입니다.

프로그래머스 - 신규 아이디 추천

문제 설명에서 제시한 단계별로 id를 변환하는 과정을 구현합니다.

  1. 모든 대문자를 대응되는 소문자로 치환합니다.
  2. 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
  3. 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
  4. 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
  5. 빈 문자열이라면, "a"를 대입합니다.
  6. 길이가 16자 이상이면, 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
    만약 제거 후 마침표(.)가 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
  7. 길이가 2자 이하라면, 마지막 문자를 길이가 3이 될 때까지 반복해서 끝에 붙입니다.
function solution(new_id) {
    const answer = new_id
        .toLowerCase() // 1
        .replace(/[^\w-_.]/g, '') // 2
        .replace(/\.{2,}/g, '.') // 3
        .replace(/^\.|\.$/g, '') // 4
        .replace(/^$/, 'a') // 5
        .slice(0, 15).replace(/\.$/, ''); // 6
    const len = answer.length;
    return len > 2 ? answer : answer + answer.charAt(len - 1).repeat(3 - len); // 7
}

3단계를 처음에 replace(/\.+/g, '.')로 했는데, 2개 이상만 치환하는 것이 더 정확하겠다 싶어 replace(/\.{2,}/g/, '.') 수정했습니다.

5단계는 정규표현식으로 replace 하는 방법보다 length를 구해 비교하는 방법이 좀 더 직관적일 수 있으나 체이닝을 계속하고 싶어서 위와 같이 구현했습니다ㅎㅎ.

 

다른 사람의 풀이에서 새롭게 알게 된 함수가 있는데요. 5단계와 7단계에서 String.prototype.padEnd() 함수를 사용하신 분이 있더라구요. ES2017에 추가된 함수로 현재 문자열에 다른 문자열을 채워, 주어진 길이를 만족하는 새로운 문자열을 반환하는 함수라고 합니다.

320x100
댓글