Algorithm/programmers
[프로그래머스] LV1 - 신규 아이디 추천문제
낭강
2021. 6. 10. 15:40
문제
https://programmers.co.kr/learn/courses/30/lessons/72410
코딩테스트 연습 - 신규 아이디 추천
카카오에 입사한 신입 개발자 네오는 "카카오계정개발팀"에 배치되어, 카카오 서비스에 가입하는 유저들의 아이디를 생성하는 업무를 담당하게 되었습니다. "네오"에게 주어진 첫 업무는 새로
programmers.co.kr
소스코드
#include <string>
#include <vector>
using namespace std;
string solution(string new_id) {
for (int i = 0; i < new_id.size(); i++) {
if ('A' <= new_id[i] && new_id[i] <= 'Z')
new_id[i] = new_id[i] - 'A' + 'a';
}
for (int i = 0; i < new_id.size();) {
if (('a' <= new_id[i] && new_id[i] <= 'z') || ('0' <= new_id[i] && new_id[i] <= '9') || new_id[i] == '-' || new_id[i] == '_' || new_id[i] == '.')
{
i++;
continue;
}
new_id.erase(new_id.begin()+i);
}
for (int i = 1; i < new_id.size();) {
if (new_id[i] == '.' && new_id[i - 1] == '.') {
new_id.erase(new_id.begin() + i);
continue;
}
else i++;
}
if (new_id[0] == '.') new_id.erase(new_id.begin());
if (new_id[new_id.size() - 1] == '.') new_id.erase(new_id.end()-1);
if (new_id.empty()) new_id = "a";
if (new_id.size() >= 16) {
while (new_id.size() != 15) {
new_id.erase(new_id.begin() + 15);
}
}
if (new_id[new_id.size() - 1] == '.') new_id.erase(new_id.end() - 1);
if (new_id.size() <= 2) {
while (new_id.size() != 3) {
new_id += new_id.back();
}
}
string answer = new_id;
return answer;
}
해설
1번 조건 - 모든 대문자를 소문자로 변경 new_id[i] = new_id[i] - 'A' + 'a';
2번 조건 - 조건에 없는 문자는 삭제
3번 조건 - .이 2번이상 나와있으면, 한개로 치환
4번 조건 - .이 처음이나 끝에 있을시 삭제
5번 조건 - 빈문자열일경우 a를 삽입
6번 조건 - 16글자 이상이라면 15글자 뒤로는 삭제
7번 조건 - 2글자 이하인경우 3글자가 될 때까지 문자열 가장끝부분을 추가
조건에 맞게 소스코드를 하나씩 작성해주면된다.