[프로그래머스] 2021 KAKAO BLIND RECRUITMENT 신규 아이디 추천 (JAVA)

·2023년 1월 13일
0

프로그래머스

목록 보기
15/59

📌 문제 설명

카카오에 입사한 신입 개발자 네오는 "카카오계정개발팀"에 배치되어, 카카오 서비스에 가입하는 유저들의 아이디를 생성하는 업무를 담당하게 되었습니다. "네오"에게 주어진 첫 업무는 새로 가입하는 유저들이 카카오 아이디 규칙에 맞지 않는 아이디를 입력했을 때, 입력된 아이디와 유사하면서 규칙에 맞는 아이디를 추천해주는 프로그램을 개발하는 것입니다.
다음은 카카오 아이디의 규칙입니다.

  • 아이디의 길이는 3자 이상 15자 이하여야 합니다.
  • 아이디는 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.) 문자만 사용할 수 있습니다.
  • 단, 마침표(.)는 처음과 끝에 사용할 수 없으며 또한 연속으로 사용할 수 없습니다.
    "네오"는 다음과 같이 7단계의 순차적인 처리 과정을 통해 신규 유저가 입력한 아이디가 카카오 아이디 규칙에 맞는 지 검사하고 규칙에 맞지 않은 경우 규칙에 맞는 새로운 아이디를 추천해 주려고 합니다.
    신규 유저가 입력한 아이디가 new_id 라고 한다면,
    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이 될 때까지 반복해서 끝에 붙입니다.

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

📌 제한 사항

  • new_id는 길이 1 이상 1,000 이하인 문자열입니다.
  • new_id는 알파벳 대문자, 알파벳 소문자, 숫자, 특수문자로 구성되어 있습니다.
  • new_id에 나타날 수 있는 특수문자는 -_.~!@#$%^&*()=+[{]}:?,<>/ 로 한정됩니다.

📌 입출력 예

nonew_idresult
예1"...!@BaT#*..y.abcdefghijklm""bat.y.abcdefghi"
예2"z-+.^.""z--"
예3"=.=""aaa"
예4"123_.def""123_.def"
예5"abcdefghijklmn.p""abcdefghijklmn"

📌 코드

생각보다 가독성이 가출했네요........

class Solution {
    public String solution(String new_id) {
        String answer = new_id.toLowerCase(); //1단계
        answer = answer.replaceAll("[^a-z0-9-_.]", ""); //2단계
        answer = answer.replaceAll("\\.{2,}", "."); //3단계
        if(answer.substring(0,1).equals("."))
            answer = answer.substring(1);
        if(answer.endsWith("."))
            answer = answer.substring(0, answer.length() - 1); //4단계
        if(answer.equals("")) answer = answer.concat("a"); //5단계
        if(answer.length() >= 16) {
            answer = answer.substring(0, 15);
            if(answer.substring(answer.length() - 1).equals("."))
                answer = answer.substring(0, answer.length()-1);
        } //6단계
        if(answer.length() <= 2){ //7단계
            while(true){
               if(answer.length() == 3) break;
               answer = answer.concat(answer.substring(answer.length() - 1));
            }
        }
      return answer;
    }
}

📌 문제 해결 과정

💡 1단계: toLowerCase()를 통해 new_id의 대문자에 대해 모두 소문자로 바꿔서 answer에 담아 주었다

💡 2단계: 정규 표현식과 replaceAll()을 사용해 영어 소문자와 숫자 -, _, .의 문자를 제외한 문자들을 다 삭제시켜 주었다

💡 3단계: 정규 표현식과 replaceAll()을 사용해 .이 두 개 이상 나올 때는 . 하나로 치환해 줄 수 있도록 하였다 ( . 문자 그 자체로 나타내 주기 위해 백슬래시를 사용하였고, {2,}를 사용해 .이 두 개 이상일 때를 구분할 수 있게 해 주었다 ❕

💡 4단계: 맨 첫 문자가 .와 같을 때 substring()을 이용해 인덱스 0을 제외한 나머지 문자들을 answer에 넣어 주고, 맨 마지막 문자가 .와 같을 때 substring()을 이용해 맨 첫 인덱스부터 맨 마지막 인덱스를 제외한 문자열을 answer에 넣어 주었다

💡 5단계: 단계를 거쳐 오면서 answer이 빈 문자열이 되었다면 concat()을 이용해 a 하나를 연결시켜 주었다

💡 6단계: answer의 길이가 16 이상이라면 substring()을 이용해 인덱스 0부터 인덱스 14까지만 살려 두어 그 뒤의 문자열들은 없어지게 했다 만약 이렇게 남겨진 15개의 문자 중 마지막 문자가 .이 되었다면 또한 substring()을 이용해 .을 잘라서 없애 주었다

💡 7단계: 만약 answer의 길이가 2 이하라면 반복문을 돌려 substring()으로 맨 마지막 문자를 잘라내 concat()을 이용해 answer의 길이가 3이 될 때까지 잘라낸 문자를 계속 연결시키게 하였다 길이가 3이 되면 break로 반복문을 탈출하게 하였다 이렇게 여러 단계를 거쳐 온 최종 answer를 리턴 하게 해 주었다

📌 느낀 점..........

replace()에서는 정규 표현식 사용이 불가하지만 replaceAll()에서는 사용 가능하다는 걸 처음 알았다... 그리고 정규 표현식 사용에 익숙한 편이 아니라서 코드 짜면서 거의 처음 사용해 봤는데 사용해 보니까 편리한 것 같아 정규 표현식에 사용되는 기호들을 좀 공부해야겠다는 생각이 들었다 그리고 이 문제 풀면서 startsWith()과 endsWith()을 처음 알았는데 생각보다 유용하게 쓰일 것 같았다❕ 나는 이것도 모른 채 substring()만 엄청나게 써 왔던 것이다... (내가 올린 코드들 보면 substring()이 안 쓰이는 코드가 없는 것 같다 😂) 시간은 조금 걸렸지만 생각보다 풀 만한 문제였던 것 같다

profile
공부는 많은 양을 하진 않더라도 꾸준히 매일 하기

0개의 댓글