[Algorithm/JavaScript] 신규 아이디 추천

Dico·2021년 4월 20일
0

[Algorithm/JavaScript]

목록 보기
17/18

Programmers Level.1 Question Review ✏️


문제출처: https://programmers.co.kr/learn/courses/30/lessons/72410

문제

문제 보러가기

  • 1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
  • 2단계 newid에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(), 마침표(.)를 제외한 모든 문자를 제거합니다.
  • 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) {
    //1단계, 2단계
    new_id = new_id.toLowerCase().replace(/[^a-z\d\-\_\.]/g, "");
    //3단계
    new_id = new_id.replace(/\.+\./g, '.');
    //4단계 - / 는 or을 나타냄
    new_id = new_id.replace(/^\.|\.$/g, "");
    //5단계
    if(new_id === '') new_id = "a";
    //6단계
    if(new_id.length >= 16) {
        //ew_id = new_id.replace(/a-z/g, "")
        new_id = new_id.slice(0, 15).replace(/\.$/g, '');
    //7단계
    }
    if(new_id.length <= 2) {
            const lastLetter = new_id[new_id.length - 1];
            const requiredCount = 3 - new_id.length;
            for(let i = 0; i < requiredCount; i++){
                new_id += lastLetter;
            }
    }
    return new_id;
}

오늘의 Lesson

  • 대괄호([]) 안의 조건을 찾는다. (a-z는 문자열,d는 숫자 찾기)
  • 캐럿(^)을 쓰면 !를 사용하는 것과 같이 불일치조건을 반환하게 된다.
  • 캐럿(^)의 또 다른 의미는 가장 첫번째 자리가 된다. 즉, ^\.은 가장 첫번째 자리에 .가 있는 지를 확인하는 것.
  • 반면$는 마지막 자리를 체크. 즉, \.$는 마지막 자리에 .가 있는 지를 확인하는 것.
  • |는 OR 연산자의 역할.
  • +를 사용해서 연속되는 문자를 검색할 수 있다.
  • \s는 공백을 의미한다.
  • 연속 검색은{최소, 최대} 로 표현된다. 예)\.{3,}.이 3개 이상 (연속해서)오는 경우 전부를 검색. \.{3, 6}.이 3개 이상 6개 이하로 오는 경우 전부를 검색.
profile
프린이의 코묻은 코드가 쌓이는 공간

0개의 댓글