ericagong / algorithm_solving

2 stars 0 forks source link

[정규표현식] 신규 아이디 추천 #67

Open ericagong opened 1 year ago

ericagong commented 1 year ago

⭐ 성찰

  1. 문자열에서 특정한 조건에 만족하는 부분을 삭제할 때, String.prototype.replace(pattern, '')을 사용. 이 때, pattern 정규식에 /g 플래그 주면 replaceAll로 동작. ㄴ String.prototype.replaceAll(pattern, '') 사용 시 pattern에 /g 플래그 없으면 오류 발생.
  2. 문자열에서 특정 부분만 추출하는 경우, String.prototype.slice(startIdx, endIdx) 사용 or String.prototype.substring(startIdx, endIdx) (String.prototype.substr은 deprecated) ㄴ cf) 배열은 Array.prorotype.slice, Array.prorotype.splice 모두 가능하나 String은 splice 불가함에 주의하기!

❓ 문제 상황

[신규 아이디 추천]() 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이 될 때까지 반복해서 끝에 붙입니다.

👨‍💻 문제 해결

✅ 1차 풀이: 정규식과 문자열 메소드를 사용한 풀이

- 문제에서 주어진 흐름대로 적절한 메소드를 사용해 구현


function solution(new_id) {
  let result = new_id;

  result = result
    .toLowerCase() // 1단계
    .replace(/[^\w-_.]/g, "") // 2단계
    .replace(/\.{2,}/g, "."); // 3단계

    // 4단계
  if (result[0] === ".") {
    result = result.slice(1);
  }
  if (result[result.length - 1] === ".") {
    result = result.slice(0, result.length - 1);
  }

    // 5단계
  if (result === "") {
    result = "a";
  }

    // 6단계
  if (result.length >= 16) {
    result = result.slice(0, 15);
    if (result[result.length - 1] === ".") {
      result = result.slice(0, 14);
    }
  }

    // 7단계
  if (result.length <= 2) {
    result = result.padEnd(3, result[result.length - 1]);
  }

  return result;
}