본문 바로가기
공부

(프로그래머스)신규 아이디 추천

by 하프상 2021. 10. 14.

Level1

언어 : C++


신규 유저가 입력한 아이디를 나타내는 new_id가 매개변수로 주어질 때, "네오"가 설계한 7단계의 처리 과정을 거친 후의 추천 아이디를 return 하도록 solution 함수를 완성해 주세요.

 

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 <vector>
#include <iostream>
#include <algorithm>

using namespace std;

string solution(string new_id) {
    string answer = "";
    int i = 0;
    int j = 0;
    
    answer = new_id;
    
    for(i=0; i<answer.size(); i++)
    {
        answer[i] = tolower(answer[i]); // Step_1

        if((isalpha(answer[i]) == 0) 
            && (isdigit(answer[i]) == 0) 
            && (answer[i] != '-') 
            && (answer[i] != '_') 
            && (answer[i] != '.'))
        {
            answer[i] = ' '; // Step_2
        }
    }
    answer.erase(remove(answer.begin(), answer.end(), ' '), answer.end());

    for(i=0; i<answer.size(); i++) // Step_3
    {
       if((answer[i] == '.') && ((answer[i+1] == '.')))
        {
            answer[i+1] = ' ';
            for(j=i+2; j<answer.size(); j++)
            {
                if(answer[j] == '.')
                {
                    answer[j] = ' ';
                }
                else
                {
                    break;
                }
            }
        } 
    }
    answer.erase(remove(answer.begin(), answer.end(), ' '), answer.end());

    if(answer[0] == '.')
    {
        answer[0] = ' '; // Step_4
    }
    
    if(answer[answer.size()-1] == '.')
    {
        answer[answer.size()-1] = ' '; // Step_4
    }
    
    answer.erase(remove(answer.begin(), answer.end(), ' '), answer.end());

    if(answer.size() == 0) // Step_5
    {
        answer = 'a';
    }

    if(answer.size() >= 15) // Step_6
    {
        for(i=0; i<answer.size(); i++)
        {
            answer[i+15] = ' ';
            if(answer[i+14] == '.')
            {
                answer[i+14] = ' ';
            }
        }
    }
    else if(answer.size() <= 2)
    {
        answer += answer[answer.size()-1];          
        if(answer.size() < 3)
        {
            answer += answer[answer.size()-1]; 
        }
    }else{/*nothing*/}
    answer.erase(remove(answer.begin(), answer.end(), ' '), answer.end());
  
    return answer;
}

*********************************************************************************************************

문제를 다 기재하진 않았지만 자세히 읽어보면 ' 순차적인 처리 과정을 통해'

이라는 문구가 있다.

처음에는 7단계중에서 빨리 처리할 수 있는 것부터 처리하는 식으로 하다보니

결과값이 자꾸 이상했고..

결과적으론 문제에서 시킨대로 순차적으로 구성을 배치하니 문제가 풀려갔다..

앞으론 하라는 대로만 해야겠다!

*********************************************************************************************************

'공부' 카테고리의 다른 글

(프로그래머스)크레인 인형뽑기 게임  (0) 2021.10.23
(프로그래머스)내적  (0) 2021.10.18
C++_TIL  (0) 2021.10.13
(프로그래머스)음양 더하기  (0) 2021.10.08
(프로그래머스)로또의 최고 순위와 최저 순위  (0) 2021.10.08

댓글