var d = ['프로그래머스', '신규 아이디 추천'];

fbghgus123·2021년 2월 24일
0
post-thumbnail

❓ 문제

코딩테스트 연습 > 2021 KAKAO BLIND RECRUITMENT > 신규 아이디 추천

신규 유저가 입력한 아이디를 나타내는 new_id가 매개변수로 주어질 때, 네오가 설계한 7단계의 처리 과정을 거친 후의 추천 아이디를 return 하도록 solution 함수를 완성해 주세요.

7 단계 처리 과정

  • 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이 될 때까지 반복해서 끝에 붙입니다.

👨‍🔧 접근

- 문자열 처리 문제 ... 하나 하나 풀어보자

첫 번째 고민은 배열로 처리할까, 문자열로 처리할까에 대한 고민이였다. 자바스크립트로 배열을 처리하는 방법은 지난 번에 어느정도 했었고, 문자열로 처리하는 문제는 거의 처음이라 문자열로 처리하기로 했다.

1단계는 .toLowerCase() 로 손쉽게 처리
2단계부터 어떻게 예외를 처리할까 고민이였다.

처음 생각해낸 것은 아스키 코드로 범위를 정하는 것이였는데, 코드의 길이도 길어지고 무엇보다 실패하는 케이스가 생기는 것이었다.

- 정규 표현식 ?

방법을 찾아보던 중 정규 표현식이라는 것을 알게 되었다.
정규 표현식과 replace를 사용한다면 적절하게 원하는 문자를 교체할 수 있을것.

💻 코드

function solution(new_id) {
    var answer = '';
    
    answer = new_id.toLowerCase(); // 1단계
    
    answer = answer.replace(/[^0-9a-z-_.]/g,""); // 2단계

    answer = answer.replace(/[.]+/g,"."); // 3단계
  
    if(answer.charAt(0) === '.') {answer = answer.slice(1,answer.length);}
    if(answer.charAt(answer.length-1) === '.') {answer = answer.slice(0,answer.length-1);} // 4단계
  
    if(answer === '') {answer = 'a';} // 5단계
    
    if(answer.length > 15) {answer = answer.slice(0,15);}
    if(answer.charAt(answer.length-1) === '.') {answer = answer.slice(0,14);} // 6단계

    while(answer.length < 3){answer += answer.charAt(answer.length-1);} // 7단계
    
    return answer;
}

- 다른 사람의 풀이

function solution(new_id) {
    const answer = new_id
        .toLowerCase() // 1
        .replace(/[^\w-_.]/g, '') // 2
        .replace(/\.+/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);
}

👨‍🏫 리뷰

  • 정규 표현식을 사용하면 보다 깔끔하게 문자열을 처리할 수 있다.
    정규식 모질라
profile
컴공과 학생 입니다.

0개의 댓글

관련 채용 정보