프로그래밍 공방

[프로그래머스] 신규 아이디 추천 본문

개발/문제해결

[프로그래머스] 신규 아이디 추천

hyosupsong 2021. 1. 27. 01:35

문제

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

 

코딩테스트 연습 - 신규 아이디 추천

카카오에 입사한 신입 개발자 네오는 카카오계정개발팀에 배치되어, 카카오 서비스에 가입하는 유저들의 아이디를 생성하는 업무를 담당하게 되었습니다. 네오에게 주어진 첫 업무는 새로 가

programmers.co.kr

문제해결방법

문자열을 Char 배열로 옮기고 배열을 앞에서부터 돌며 1~3단계를 처리해준다.

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
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package Programmers;
 
public class Solution_신규아이디추천 {
    public static String solution(String new_id) {
        String answer = "";
        int s = 0, e = 0;
        char[] ch = new char[new_id.length()];
        int length = new_id.length();
        ch = new char[length+3];
        for(int i=0; i<length; i++) ch[i] = new_id.charAt(i);
        while(e<length) {
            if(s!=e) ch[s] = ch[e];
            if(ch[s]>='A' && ch[s]<='Z') {
                ch[s] = (char) (ch[s]-'A'+'a');
                s++;
                e++;
            } else if (ch[s]=='.') {
                if(s!=0) {
                    if(ch[s-1]!='.') s++;
                } else {
                    s++;
                }
                e++;
            } else if((ch[s]>='a' && ch[s]<='z'|| (ch[s]>='0' && ch[s]<='9'|| ch[s]=='-' || ch[s]=='_') {
                s++;
                e++;
            } else e++;
        }
        // 양 끝 . 없앰
        e = s;
        s = 0;
        if(ch[s]=='.') s++;
        if(s==e) ch[e++]='a';
        if(e-s>15) e = s+15;
        if(ch[e-1]=='.') e--;
        if(e-s<3) {
            for(int i=e-s; i<3; i++) {
                ch[e] = ch[e++-1];
            }
        }
        StringBuilder sb = new StringBuilder();
        for(int i=s; i<e; i++) sb.append(ch[i]);
        answer = sb.toString();
        return answer;
    }
    
    public static void main(String[] args) {
        String new_id = "...!@BaT#*..y.abcdefghijklm";
        System.out.println(solution(new_id));
    }
}
cs


코드에 대한 피드백이나 더 좋은 아이디어는 언제나 환영입니다.

'개발 > 문제해결' 카테고리의 다른 글

[프로그래머스] 광고 삽입  (5) 2021.01.27
[백준] 1238번 : 파티  (0) 2021.01.27
[프로그래머스] 합승 택시 요금  (0) 2021.01.26
[백준] 1010번 : 다리놓기  (0) 2021.01.26
[백준] 1766번 : 문제집  (0) 2021.01.26