문자열 / 구현 문제.
Level 1은 크게 어려운 문제는 아니라고 생각했다.
막상 코딩 테스트에서 만나면 시간을 많이 잡아먹을 것 같다.
문제풀이
문제에 나온 그대로, 다음과 같은 순서로 구현해주면 된다.
아이디의 길이 : 3 ~ 15
소문자, 숫자, -, _, . 사용 가능.
마침표(.)는 처음과 끝에 사용 불가
마침표는 연속 사용 불가
단계를 통해서 규칙에 맞는 새로운 아이디 추천
1. 모든 대문자를 소문자로 치환.
2. 소문자, 숫자, -, _, .을 제외한 모든 문자 제거
3. 마침표가 2번 이상 연속된 부분 하나의 마침표로 변경
4. 마침표가 처음이나 끝에 있다면 제거
5. 빈 문자열일 경우 "a" 대입
6. 길이가 16자 이상일 경우, 처음 15개 제외 나머지를 모두 제거한다. 제거 후 마지막에 마침표 존재 시 제거
7. 길이가 2자 이하라면, new_id의 마지막 문자를 길이가 3이 될 때까지 반복해서 끝에 붙임.
string solution(string new_id) {
int diff = 'a' - 'A';
string answer = new_id;
//1단계. 모든 대문자 소문자로 치환.
for (int i = 0; i < answer.length(); i++) {
if (answer[i] >= 'A' && answer[i] <= 'Z') {
answer[i] += diff;
}
}
//2단계. 소문자, 숫자, -, _, .을 제외한 모든 문자 제거
for (int i = 0; i < answer.length(); i++) {
if (!(answer[i] >= 'a' && answer[i] <= 'z') &&
!(answer[i] >= '0' && answer[i] <= '9') &&
answer[i] != '-' && answer[i] != '_' && answer[i] != '.') {
answer.erase(answer.begin() + i);
i--;
}
}
int prevPointIdx = -2;
//3단계 마침표 두 번 이상 연속된 곳 제거.
for (int i = 0; i < answer.length(); i++) {
if (answer[i] == '.') {
if (i - 1 == prevPointIdx) {
answer.erase(answer.begin() + i);
i--;
}
else {
prevPointIdx = i;
}
}
}
//4단계 마침표가 처음이나 끝에 있다면 제거
while (answer.length() > 0 && answer[0] == '.') {
answer.erase(answer.begin());
}
while (answer.length() > 0 && answer[answer.length() - 1] == '.') {
answer.erase(answer.begin() + (answer.length() - 1) );
}
//5단계 빈 문자열일 경우 "a" 대입
if (answer.length() == 0) {
answer = "a";
}
//6단계 길이가 16자 이상일 경우, 처음 15개 제외 나머지를 모두 제거한다. 제거 후 마지막에 마침표 존재 시 제거
while (answer.length() > 15) {
answer.erase(answer.begin() + (answer.length() - 1));
}
while (answer.length() > 0 && answer[answer.length() - 1] == '.') {
answer.erase(answer.begin() + (answer.length() - 1));
}
//7단계 길이가 2자 이하라면, new_id의 마지막 문자를 길이가 3이 될 때까지 반복해서 끝에 붙임.
while (answer.length() <= 2) {
answer += answer[answer.length() - 1];
}
return answer;
}
좀 더 효율적으로 풀 수 있을 것 같지만, 만약 시험이라면 효율보다는 정답에 초점을 두고 풀었다.
'알고리즘 > Programmers' 카테고리의 다른 글
[C++] 프로그래머스 2020 KAKAO BLIND RECRUITMENT Level 1 키패드 누르기 (2) | 2021.11.16 |
---|