λ³Έλ¬Έ λ°”λ‘œκ°€κΈ°

Algorithm

[Algoritm/Java][ν”„λ‘œκ·Έλž˜λ¨ΈμŠ€] μ‹ κ·œ 아이디 μΆ”μ²œ

λ°˜μ‘ν˜•

[ν”„λ‘œκ·Έλž˜λ¨ΈμŠ€] μ‹ κ·œ 아이디 μΆ”μ²œ

https://programmers.co.kr/learn/courses/30/lessons/72410

문제 μ„€λͺ…

μΉ΄μΉ΄μ˜€μ— μž…μ‚¬ν•œ μ‹ μž… 개발자 λ„€μ˜€λŠ” "μΉ΄μΉ΄μ˜€κ³„μ •κ°œλ°œνŒ€"에 λ°°μΉ˜λ˜μ–΄, 카카였 μ„œλΉ„μŠ€μ— κ°€μž…ν•˜λŠ” μœ μ €λ“€μ˜ 아이디λ₯Ό μƒμ„±ν•˜λŠ” 업무λ₯Ό λ‹΄λ‹Ήν•˜κ²Œ λ˜μ—ˆμŠ΅λ‹ˆλ‹€. "λ„€μ˜€"μ—κ²Œ 주어진 첫 μ—…λ¬΄λŠ” μƒˆλ‘œ κ°€μž…ν•˜λŠ” μœ μ €λ“€μ΄ 카카였 아이디 κ·œμΉ™μ— λ§žμ§€ μ•ŠλŠ” 아이디λ₯Ό μž…λ ₯ν–ˆμ„ λ•Œ, μž…λ ₯된 아이디와 μœ μ‚¬ν•˜λ©΄μ„œ κ·œμΉ™μ— λ§žλŠ” 아이디λ₯Ό μΆ”μ²œν•΄μ£ΌλŠ” ν”„λ‘œκ·Έλž¨μ„ κ°œλ°œν•˜λŠ” κ²ƒμž…λ‹ˆλ‹€.
λ‹€μŒμ€ 카카였 μ•„μ΄λ””μ˜ κ·œμΉ™μž…λ‹ˆλ‹€.

μ•„μ΄λ””μ˜ κΈΈμ΄λŠ” 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 값이 "...!@BaT#*..y.abcdefghijklm" 라면, μœ„ 7단계λ₯Ό 거치고 λ‚˜λ©΄ new_idλŠ” μ•„λž˜μ™€ 같이 λ³€κ²½λ©λ‹ˆλ‹€.

1단계 λŒ€λ¬Έμž 'B'와 'T'κ°€ μ†Œλ¬Έμž 'b'와 't'둜 λ°”λ€Œμ—ˆμŠ΅λ‹ˆλ‹€.
"...!@BaT#..y.abcdefghijklm" β†’ "...!@bat#..y.abcdefghijklm"

2단계 '!', '@', '#', '' λ¬Έμžκ°€ μ œκ±°λ˜μ—ˆμŠ΅λ‹ˆλ‹€.
"...!@bat#
..y.abcdefghijklm" β†’ "...bat..y.abcdefghijklm"

3단계 '...'와 '..' κ°€ '.'둜 λ°”λ€Œμ—ˆμŠ΅λ‹ˆλ‹€.
"...bat..y.abcdefghijklm" β†’ ".bat.y.abcdefghijklm"

4단계 μ•„μ΄λ””μ˜ μ²˜μŒμ— μœ„μΉ˜ν•œ '.'κ°€ μ œκ±°λ˜μ—ˆμŠ΅λ‹ˆλ‹€.
".bat.y.abcdefghijklm" β†’ "bat.y.abcdefghijklm"

5단계 아이디가 빈 λ¬Έμžμ—΄μ΄ μ•„λ‹ˆλ―€λ‘œ λ³€ν™”κ°€ μ—†μŠ΅λ‹ˆλ‹€.
"bat.y.abcdefghijklm" β†’ "bat.y.abcdefghijklm"

6단계 μ•„μ΄λ””μ˜ 길이가 16자 μ΄μƒμ΄λ―€λ‘œ, 처음 15자λ₯Ό μ œμ™Έν•œ λ‚˜λ¨Έμ§€ λ¬Έμžλ“€μ΄ μ œκ±°λ˜μ—ˆμŠ΅λ‹ˆλ‹€.
"bat.y.abcdefghijklm" β†’ "bat.y.abcdefghi"

7단계 μ•„μ΄λ””μ˜ 길이가 2자 μ΄ν•˜κ°€ μ•„λ‹ˆλ―€λ‘œ λ³€ν™”κ°€ μ—†μŠ΅λ‹ˆλ‹€.
"bat.y.abcdefghi" β†’ "bat.y.abcdefghi"

λ”°λΌμ„œ μ‹ κ·œ μœ μ €κ°€ μž…λ ₯ν•œ new_idκ°€ "...!@BaT#*..y.abcdefghijklm"일 λ•Œ, λ„€μ˜€μ˜ ν”„λ‘œκ·Έλž¨μ΄ μΆ”μ²œν•˜λŠ” μƒˆλ‘œμš΄ μ•„μ΄λ””λŠ” "bat.y.abcdefghi" μž…λ‹ˆλ‹€.

μ œν•œμ‚¬ν•­

new_idλŠ” 길이 1 이상 1,000 μ΄ν•˜μΈ λ¬Έμžμ—΄μž…λ‹ˆλ‹€.
new_idλŠ” μ•ŒνŒŒλ²³ λŒ€λ¬Έμž, μ•ŒνŒŒλ²³ μ†Œλ¬Έμž, 숫자, 특수문자둜 κ΅¬μ„±λ˜μ–΄ μžˆμŠ΅λ‹ˆλ‹€.
new_id에 λ‚˜νƒ€λ‚  수 μžˆλŠ” νŠΉμˆ˜λ¬ΈμžλŠ” -_.~!@#$%^&*()=+[{]}:?,<>/ 둜 ν•œμ •λ©λ‹ˆλ‹€.

Code

class Solution {
    public String solution(String new_id) {
        String step1 = new_id.toLowerCase(); //1단계

        String step2 = new String(); //2단계
        for(int i = 0; i<step1.length(); i++){
            char tmp = step1.charAt(i);
            if((tmp>='a'&&tmp<='z')||(tmp>='0'&&tmp<='9')||tmp=='-'||tmp=='_'||tmp=='.')
                step2+= Character.toString(tmp);
        }

        String step3 = step2.replaceAll("[.]{2,}","."); //3단계

        String step4 = new String(); //4단계
        if(step3.charAt(0)=='.') step3 = step3.substring(1,step3.length());
        if(step3.length()!=0){
            if(step3.charAt(step3.length()-1)=='.') step3 = step3.substring(0,step3.length()-1);
        }
        step4 = step3;

        String step5 = step4; //5단계
        if(step4.length()==0) step5 = "a";

        String step6 = step5; //6단계
        if(step5.length()>15){
            step6 = step5.substring(0,15);
            if(step6.charAt(step6.length()-1)=='.') step6 = step6.substring(0,step6.length()-1);
        }

        String step7 = step6; //7단계
        while(step7.length()<3){
            step7+= Character.toString(step7.charAt(step7.length()-1));
        }
        return step7;
    }
}

Code μ„€λͺ…

문제 μ„€λͺ…에 μžˆλŠ” 1~7단계λ₯Ό κ·ΈλŒ€λ‘œ κ΅¬ν˜„ν•˜λ €κ³  ν–ˆλ‹€.
각각 λ‹¨κ³„λ§ˆλ‹€ String λ³€μˆ˜λ₯Ό μ„ μ–Έν•΄μ£Όμ–΄μ„œ 단계에 λ§žλŠ” 처리λ₯Ό ν•΄μ£Όμ—ˆλ‹€.

배운점

λ¬Έμžμ—΄μ„ μ†Œλ¬Έμžλ‘œ λ°”κΎΈλŠ” toLowerCase()ν•¨μˆ˜μ™€ λŒ€λ¬Έμžλ‘œ λ°”κΎΈλŠ” toUpperCase()ν•¨μˆ˜λ₯Ό μ‚¬μš©ν–ˆλ‹€.
그리고 2λ‹¨κ³„μ—μ„œ String에 char을 더해주기 μœ„ν•΄μ„œ char을 String으둜 λ°”κΏ”μ£ΌλŠ” Character.toString(char) ν•¨μˆ˜λ₯Ό μ‚¬μš©ν–ˆλ‹€.
그리고 λ‹€λ₯Έ μ‚¬λžŒμ˜ 풀이λ₯Ό ν†΅ν•΄μ„œ μ •κ·œν‘œν˜„μ‹μ΄λΌλŠ” 것을 μ•Œκ²Œλ˜μ—ˆκ³  ꡉμž₯히 κΈ΄ μ½”λ“œκ°€ 짧게 λ³€ν•˜λŠ”κ²ƒμ„ λ³΄μ•˜λ‹€.

μ •κ·œν‘œν˜„μ‹μ„ μ‚¬μš©ν•œ Code

class Solution {
    public String solution(String new_id) {
        String answer = "";
        String temp = new_id.toLowerCase();

        temp = temp.replaceAll("[^-_.a-z0-9]","");
        System.out.println(temp);
        temp = temp.replaceAll("[.]{2,}",".");
        temp = temp.replaceAll("^[.]|[.]$","");
        System.out.println(temp.length());
        if(temp.equals(""))
            temp+="a";
        if(temp.length() >=16){
            temp = temp.substring(0,15);
            temp=temp.replaceAll("^[.]|[.]$","");
        }
        if(temp.length()<=2)
            while(temp.length()<3)
                temp+=temp.charAt(temp.length()-1);

        answer=temp;
        return answer;
    }
}
λ°˜μ‘ν˜•