Game Develop

[Algorithm] Programmers :: n진수 게임 본문

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<intchar> 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개가 있어야 한다는 뜻이다.