[Java] 2021 KAKAO BLIND RECRUIMENT- 신규 아이디 추천
https://programmers.co.kr/learn/courses/30/lessons/72410?language=java
코딩테스트 연습 - 신규 아이디 추천
카카오에 입사한 신입 개발자 네오는 "카카오계정개발팀"에 배치되어, 카카오 서비스에 가입하는 유저들의 아이디를 생성하는 업무를 담당하게 되었습니다. "네오"에게 주어진 첫 업무는 새로
programmers.co.kr
오늘의 알고리즘 스터디 문제는 쉽지만 많은 것들을 배울 수 있었던 문제 였다.
✔ 입출력 예시
💡 포인트
1️⃣ 각 규칙의 단계에 맞게 순서대로 과정이 이루어져야 한다.
2️⃣ 정규표현식을 사용하면 더 효율적인 코드를 구현할 수 있다.
1️⃣ 정규표현식을 사용하지 않은 첫번째 시도
❓ 풀이과정
1️⃣ toLowerCase()를 이용하여 모두 소문자로 변경
2️⃣ 문자열 new_id를 char형으로 분리하여 제시된 조건에 부합할 경우에만 StringBuilder에 append()
3️⃣ 연속된 .이 없을 때까지 while문을 이용해서 . 한 개로 변환
4️⃣ 문자열의 첫번째 문자와 마지막 문자 모두를 검사하고 .이 있다면 substring()을 이용하여 . 문자열 제거
5️⃣ ~ 6️⃣ 문자열의 길이에 따라 단계 시행
7️⃣ 만약, 1️⃣ ~ 6️⃣의 단계를 수행한 new_id의 길이가 3보다 작다면 3이상이 될때까지 while문을 이용하여 마지막 문자 추가
✔ 소스코드
public class Solution { // 신규 아이디 추천
public static void main(String[] args) {
String new_id = "...!@BaT#*..y.abcdefghijklm";
// String new_id = "z-+.^.";
// String new_id = "=.=";
// String new_id = "123_.def";
// String new_id = "abcdefghijklmn.p";
// String new_id = ".....";
// String new_id = "a";
// String new_id = "/dfeSg/Ew.";
System.out.println(solution(new_id));
}
private static String solution(String new_id) {
// 1단계
new_id = new_id.toLowerCase();
// System.out.println("1단계 : " + new_id);
StringBuilder sb = new StringBuilder();
for (int i = 0; i < new_id.length(); i++) {
char ch = new_id.charAt(i);
if (('a' <= ch && ch <= 'z') || ('0' <= ch && ch <= '9') || ch == '-' || ch == '_' || ch == '.') { // 2단계
sb.append(ch);
}
}
new_id=sb.toString();
// System.out.println("2단계 : " + new_id);
// 3단계
while(new_id.contains("..")) {
new_id = new_id.replace("..", ".");
}
// System.out.println("3단계 : " + new_id);
// 4단계
if(new_id.charAt(0) == '.') {
new_id = new_id.substring(1);
}
if(new_id.length() >= 1 && new_id.charAt(new_id.length()-1) == '.') {
new_id = new_id.substring(0, new_id.length()-1);
}
// System.out.println("4단계 : " + new_id);
if (new_id.length() == 0) { // 5단계
new_id = "a";
} else if (new_id.length() >= 16) { // 6단계
// System.out.println("16자 이상입니다.");
new_id = new_id.substring(0, 15); // 문자열 자르기
if (new_id.charAt(new_id.length() - 1) == '.') {
new_id = new_id.substring(0, new_id.length()-1);
}
}
// System.out.println("5~6단계 : " + new_id);
// 7단계
if (new_id.length() <= 2) {
char ch = new_id.charAt(new_id.length() - 1);
while (true) {
if (new_id.length() >= 3) {
break;
}
new_id += ch;
}
}
// System.out.println("7단계 : " + new_id);
return new_id;
}
}
2️⃣ 정규표현식을 사용하지 않은 두번째 시도
❓ 풀이과정
👉 풀이 방법은 위와 같다 다만 스터디원들과 함께 리뷰를 한 결과 코드를 더 깔끔하게 작성할 수 있는 방법을 알아냈다.
2️⃣ Character.isLowerCase()로 소문자인지 확인, Character.isDigit()로 숫자인지 확인
4️⃣ startsWith()로 첫 문자 판단, endsWith()로 마지막 문자 판단
✔ 소스코드
public class Solution { // 신규 아이디 추천
public static void main(String[] args) {
String new_id = "...!@BaT#*..y.abcdefghijklm";
// String new_id = "z-+.^.";
// String new_id = "=.=";
// String new_id = "123_.def";
// String new_id = "abcdefghijklmn.p";
// String new_id = ".....";
// String new_id = "a";
// String new_id = "/dfeSg/Ew.";
System.out.println(solution(new_id));
}
private static String solution(String new_id) {
// 1단계
new_id = new_id.toLowerCase();
// System.out.println("1단계 : " + new_id);
StringBuilder sb = new StringBuilder();
for (int i = 0; i < new_id.length(); i++) {
char ch = new_id.charAt(i);
if (Character.isLowerCase(ch) || Character.isDigit(ch) || ch == '-' || ch == '_' || ch == '.') { // 2단계
sb.append(ch);
}
}
new_id=sb.toString();
// System.out.println("2단계 : " + new_id);
// 3단계
while(new_id.contains("..")) {
new_id = new_id.replace("..", ".");
}
// System.out.println("3단계 : " + new_id);
// 4단계
if(new_id.startsWith(".")) {
new_id = new_id.substring(1);
}
if(new_id.endsWith(".")) {
new_id = new_id.substring(0, new_id.length()-1);
}
// System.out.println("4단계 : " + new_id);
if (new_id.length() == 0) { // 5단계
new_id = "a";
} else if (new_id.length() >= 16) { // 6단계
// System.out.println("16자 이상입니다.");
new_id = new_id.substring(0, 15); // 문자열 자르기
if (new_id.charAt(new_id.length() - 1) == '.') {
new_id = new_id.substring(0, new_id.length()-1);
}
}
// System.out.println("5~6단계 : " + new_id);
// 7단계
if (new_id.length() <= 2) {
char ch = new_id.charAt(new_id.length() - 1);
while (true) {
if (new_id.length() >= 3) {
break;
}
new_id += ch;
}
}
// System.out.println("7단계 : " + new_id);
return new_id;
}
}
해당 문제는 정규표현식을 사용하여 풀이를 하면 더 깔끔하다고 한다.
나중에 정규표현식을 사용한 소스코드도 업로드를 할 예정이다.