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글자가 될 때까지 문자열 가장끝부분을 추가

 

조건에 맞게 소스코드를 하나씩 작성해주면된다.