본문 바로가기

알고리즘/백준

[BOJ 10448] 유레카 이론

어떤 수가, 최대 3개 중복 허용인 삼각수의 합으로 표현되는지 알아봐야 한다.

 

 

 

그러기 위해서는, 전체 탐색을 하거나 삼각수의 합으로 표현되는지 확인하는 신기한 방법을 찾아야 하는데...

 

 

 

이 문제의 경우, 자연수의 범위가 1000까지 이므로, 전체 탐색을 해도 시간복잡도가 크지 않다.

 

 

 

전체탐색으로 문제를 풀기로 결정하면, 삼각수의 합이 1000이하인 값들을 구해놓고,

 

 

 

3중포문을 통해서, 만들 수 있는 값들을 모두 체크하면 된다.

 

 

 

해설코드(C++).

 

 

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
#include <iostream>
#include <cstring>
#include <vector>
 
using namespace std;
 
int T;
int K;
int a[1001];
vector<int> v;
 
int main() {
    int sum = 1;
    int idx = 1;
 
    memset(a, 0sizeof(a));
    while(sum <= 1000){
        v.push_back(sum);
        idx += 1;
        sum += idx;
    }
    
    for(int i = 0; i < v.size(); i++){
        for(int j = i; j < v.size(); j++){
            for(int k = j; k < v.size(); k++){
                if(v[i] + v[j] + v[k] <= 1000)
                    a[v[i] + v[j] + v[k]] = 1;
            }
        }
    }
    
    cin >> T;
    for(int i = 1; i <= T; i++){
        cin >> K;
        cout << a[K] << endl;
    }
    return 0;
}

 

 

'알고리즘 > 백준' 카테고리의 다른 글

[BOJ 2533] 사회망 서비스(SNS)  (0) 2020.06.02
[BOJ 2503] 숫자 야구  (0) 2020.06.01
[BOJ 10610] 30 (배수판정법 참고)  (0) 2020.05.31
[BOJ 2217] 로프  (0) 2020.05.30
[BOJ 2602] 돌다리 건너기  (0) 2020.05.28