programmers.co.kr/learn/courses/30/lessons/72410
<풀이>
1. 새로 가입하는 유저의 아이디를 '7단계의 처리과정'을 거쳐 추천 아이디를 생성한다.
2. 추천 아이디를 반환한다.
<해법>
문제를 푸는데 특별한 아이디어가 필요하지 않습니다. '7단계 처리과정'을 정확하게 구현하는 것이 문제의 핵심입니다. 문자열 관련 문제이므로, 문자열 처리 함수를 사용하면 보다 쉽게 구현할 수 있습니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
#include <string>
#include <vector>
using namespace std;
string solution(string new_id) {
string answer = "";
//step 1
for (int i = 0; i < new_id.length(); i++) {
new_id[i] = tolower(new_id[i]);
}
//step 2
string str = "";
for (int i = 0; i < new_id.length(); i++) {
if ((new_id[i] >= 'a' && new_id[i] <= 'z') || (new_id[i] >= '0' && new_id[i] <= '9') || new_id[i] == '-' || new_id[i] == '_' || new_id[i] == '.') {
str += new_id[i];
}
}
new_id = str;
//step 3
while (true) {
int index = new_id.find("..");
if (index == string::npos) {
break;
}
new_id.replace(index, 2, ".");
}
//step 4
if (new_id[0] == '.') {
new_id = new_id.substr(1);
}
if (new_id[new_id.length() - 1] == '.') {
new_id = new_id.substr(0, new_id.length() - 1);
}
//step 5
if (new_id == "") {
new_id = "a";
}
//step 6
if (new_id.length() >= 16) {
new_id = new_id.substr(0, 15);
if (new_id[14] == '.') {
new_id = new_id.substr(0, 14);
}
}
//step 7
if (new_id.length() <= 2) {
char lastChar = new_id[new_id.length() - 1];
while (true) {
if (new_id.length() == 3) {
break;
}
new_id += lastChar;
}
}
answer = new_id;
return answer;
}
|
문자열과 구현에 대해 알아볼 수 있는 문제였습니다.
'알고리즘 문제풀이 > 프로그래머스' 카테고리의 다른 글
[C++] 프로그래머스 - 합승 택시 요금 (0) | 2021.01.31 |
---|---|
[C++] 프로그래머스 - 메뉴 리뉴얼 (0) | 2021.01.31 |
[C++] 프로그래머스 - 압축 (0) | 2021.01.19 |
[C++] 프로그래머스 - 방금그곡 (0) | 2021.01.19 |
[C++] 프로그래머스 - 다트 게임 (0) | 2021.01.16 |