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 |
댓글