Algorithm/Programmers
[Algorithm] Programmers :: n진수 게임
MaxLevel
2023. 6. 2. 05:05
https://school.programmers.co.kr/learn/courses/30/lessons/17687
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
|
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
|
string solution(int n, int t, int m, int p)
{
string answer = "";
map<int, char> word = { {0,'0'}, {1,'1'}, {2,'2'}, {3,'3'}, {4,'4'}, {5,'5'}, {6,'6'}, {7,'7'},
{8,'8'}, {9,'9'},{10,'A'}, {11,'B'}, {12,'C'}, {13,'D'}, {14,'E'}, {15,'F'} };
string s = "01";
int num = 2;
while (s.size() < t * m + 2)
{
int temp = num;
string ts;
while (temp != 0)
{
ts.push_back(word[temp % n]);
temp = temp / n;
}
for (int i = ts.size() - 1; i >= 0; --i)
{
s += ts[i];
}
++num;
}
for (int i = p-1; i < s.size(); i += m)
{
answer += s[i];
if (answer.size() == t) break;
}
return answer;
}
|
cs |
진법변환만 할줄 알면 어렵지 않은 문제.
이어붙일 문자열 최대크기의 값을 적당히 잘 구해야 하는데, 얼추 t * m정도라 생각한다.
그냥 최대값을 넣고싶으면 미리 구할 최대갯수 1000 * 게임에 참가하는 인원 100 값인 10만정도를 넣어주면 될듯하다.
구해야할 숫자가 1000개인데 순서가 100번째라면 100번째인게 1000개가 있어야 한다는 뜻이다.