정규표현식
class Solution {
public String solution(String new_id) {
String answer = "";
// 1번
// new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
String first = new_id.toLowerCase();
// 2번
// new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
String second = first.replaceAll("[^a-z0-9-_.]","");
// 3번
// new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
String third = second.replaceAll("\\.{2,}",".");
// 4번
// new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
String fourth = third;
if(fourth.charAt(0)=='.'){
fourth = fourth.substring(1, fourth.length());
}
if(fourth.charAt(fourth.length()-1)=='.'){
fourth = fourth.substring(0, fourth.length()-1);
}
// 5번
// new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
String fifth = fourth;
if(fifth.equals("")){
fifth = "a";
}
// 6번
// new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
// 만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
String sixth = fifth;
if(sixth.length() >=16){
sixth = sixth.substring(0, 15);
if(sixth.charAt(sixth.length()-1) == '.'){
sixth = sixth.substring(0, sixth.length()-1);
}
}
// 7번
// new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.
String seventh = sixth;
while(seventh.length() <3){
seventh += seventh.charAt(seventh.length()-1);
}
answer = seventh;
return answer;
}
public static void main(String[] args) {
Solution T = new Solution();
System.out.println(T.solution("123_.def"));
}
}
'코딩테스트 > Java' 카테고리의 다른 글
[JAVA] DFS - 부분 집합 구하기 (0) | 2022.06.29 |
---|---|
[JAVA] DFS - 이진트리순회 (0) | 2022.06.29 |
[JAVA 인프런 강의] 정렬 - 버블정렬 (0) | 2022.06.27 |
[JAVA 인프런 강의] 정렬 - 선택정렬 (0) | 2022.06.27 |
[JAVA 인프런 강의] TreeSet - K번째큰수, 중복없는 정렬 (0) | 2022.06.27 |