SteffenLee

[프로그래머스/C++] 신규 아이디 추천 본문

Problem Solving/Programmers

[프로그래머스/C++] 신규 아이디 추천

SteffenLee 2022. 9. 15. 12:47

안녕하세요.

이번에는 프로그래머스 코딩 테스트 연습 Lv1. 2021 KAKAO BLIND RECRUITMENT - 신규 아이디 추천을 풀어봤습니다.

 

문제는 비밀번호를 입력받고 입력받은 비밀번호를 아래 규칙대로 바꿔주면되는 문제입니다.


1단계 new_id의 모든 대문자를 대응되는 소문자로 치환합니다.
2단계 new_id에서 알파벳 소문자, 숫자, 빼기(-), 밑줄(_), 마침표(.)를 제외한 모든 문자를 제거합니다.
3단계 new_id에서 마침표(.)가 2번 이상 연속된 부분을 하나의 마침표(.)로 치환합니다.
4단계 new_id에서 마침표(.)가 처음이나 끝에 위치한다면 제거합니다.
5단계 new_id가 빈 문자열이라면, new_id에 "a"를 대입합니다.
6단계 new_id의 길이가 16자 이상이면, new_id의 첫 15개의 문자를 제외한 나머지 문자들을 모두 제거합니다.
     만약 제거 후 마침표(.)가 new_id의 끝에 위치한다면 끝에 위치한 마침표(.) 문자를 제거합니다.
7단계 new_id의 길이가 2자 이하라면, new_id의 마지막 문자를 new_id의 길이가 3이 될 때까지 반복해서 끝에 붙입니다.

#include <string>
#include <vector>
#include <algorithm>

using namespace std;

string solution(string new_id) {
    string answer = "";
    string special = "~!@#$%^&*()=+[{]}:?,<>/";
    for (int i = 0; i < new_id.size(); ++i) {
        if (new_id[i] >= 'A' && new_id[i] <= 'Z')//1단계
            new_id[i] += 32;
    }
    for (int i = 0; i < special.size(); ++i)//2단계
        new_id.erase(remove(new_id.begin(), new_id.end(), special[i]), new_id.end());//특수문자 제거
    for (int i = 0; i < new_id.size();) {//3단계
        if (new_id[i] == '.' && new_id[i - 1] == '.') {
            new_id.erase(new_id.begin() + i);
            continue;
        }
        else
            ++i;
    }
    while (new_id.front() == '.' || new_id.back() == '.') {//4단계
        if (new_id[0] == '.') new_id.erase(0, 1);
        else if (new_id.back() == '.') new_id.pop_back();
    }
    if (new_id.empty()) new_id += 'a';
    if (new_id.size() >= 16) new_id = new_id.substr(0, 15);
    if (new_id.back() == '.') new_id.pop_back();
    while (new_id.size() < 3) new_id += new_id[new_id.size() - 1];
    answer = new_id;
    return answer;
}

감사합니다.

'Problem Solving > Programmers' 카테고리의 다른 글

[프로그래머스/C++] 크레인 인형뽑기  (0) 2022.09.14
Comments