반응형
문제
유저들의 아이디를 규칙에 맞게 추천해주는 프로그램을 개발하려합니다.
▶ 규칙
- 아이디의 길이는 3자 이상 15자 이하여야 합니다.
- 아이디는 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.) 문자만 사용할 수 있습니다.
- 단, 마침표(.)는 처음과 끝에 사용할 수 없으며 또한 연속적으로 사용 할 수 없습니다.
유저가 입력한 아이디가 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이 될 때까지 반복해서 끝에 붙입니다.
의 7단계를 통하여 유저의 아이디를 변경시키는 프로그램을 개발하는 것이 목표입니다.
▶ 제한사항
- new_id는 길이 1이상, 1,000 이하인 문자입니다.
- new_id는 알파벳 대문자, 알파벳 소문자, 숫자, 특수문자로 구성되어있습니다.
- new_id에 나타날 수 있는 특수문자는 -_.~!@#$%^&*()=+[{]}:?,<>/로 한정됩니다.
▶ 입출력 예
no | new_id | result |
예1 | "...!@BaT#*..y.abcdefghijklm" | "bat.y.abcdefghi" |
예2 | "z-+.^." | "z--" |
예3 | "=.=" | "aaa" |
예4 | "123_.def" | "123_.def" |
예5 | "abcdefghijklmn.p" | "abcdefghijklmn" |
해법
본 문제는 정규식을 활용하여 해결합니다.
- toLowerCase()
- 모든 대문자를 소문자로 치환합니다.
- replaceAll()
- 목표 String을 설정한 String으로 치환합니다.
- [^-_.a-z0-9]
- 정규식으로 [^abc]라면 abc를 제외한 문자 1개를 뜻합니다.
- a-z는 a부터 z까지의 문자를 뜻합니다.
- 0-9는 0부터 9까지의 숫자를 뜻합니다.
- 따라서 -_.a-z0-9를 제외한 문자를 뜻합니다.
- [.]+
- .이 1번 이상 반복됨을 뜻합니다.
- ^[.]|[.]$
- ^는 line이 .로 시작하는지를 뜻합니다.
- $는 line의 끝이 .로 끝나는지를 뜻합니다.
- |는 또는 을 뜻합니다.
- isEmpty()
- 비어있는지 확인합니다.
- subString()
- 인덱스에 따라 새로운 문자열을 반환합니다.
public class test {
public static String solution(String new_id) {
String s1 = "";
// 1. new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
s1 = new_id.toLowerCase();
// 2. new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
s1 = s1.replaceAll("[^-_.a-z0-9]", "");
// 3. new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
s1 = s1.replaceAll("[.]+", ".");
// 4. new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
s1 = s1.replaceAll("^[.]|[.]$", "");
// 5. new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
if(s1.isEmpty()){
s1 += "a";
}
// 6. new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
// 만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
if(s1.length() >= 16){
s1 = s1.substring(0, 15);
s1 = s1.replaceAll("[.]$", "");
}
// 7. new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.
// s1 = minString(s1);
if(s1.length() <= 2){
String sS = Character.toString(s1.charAt(s1.length()-1));
while(s1.length() < 3){
s1 += sS;
}
}
return s1;
}
반응형
'JAVA' 카테고리의 다른 글
[Java] Coding Test (키패드 누르기) (0) | 2022.08.18 |
---|---|
[Java] Coding Test (최소직사각형) (0) | 2022.08.17 |
[Java] Coding Test (신고 결과 받기) (0) | 2022.08.12 |
[Java] Coding Test (완주하지 못한 선수) (0) | 2022.08.11 |
[Java] Coding Test (예산) (0) | 2022.08.11 |