Be a developer

백준 14889 스타트와 링크 본문

sw 역량테스트

백준 14889 스타트와 링크

중국고대사 2019. 4. 13. 13:26

조건도 많지 않고, 문제도 간단하여 풀기 쉬운 문제였다.

재귀 함수를 이용하여 완전 탐색만 진행해 주면 되었다.

 

선수들을 배열로 놓고, idx를 증가시켜가며 추가하거나 추가하지 않는 경우의 수를 나누면 되었다.

추가한 선수들을 true로 두어서, cal함수에서 이중 for문을 돌며 true인 두 선수의 능력치를 더해주었다.

이어서 false인 두 선수의 능력치를 더하였다.

마지막으로 두 합의 차이를 ans vector에 저정한 후 min_element함수를 통해 출력하면 끝이난다.

 

코드는 아래와 같다.

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
#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
 
vector<int> ans;
int n;
int s[20][20];
int check[20];
 
void cal() {
    int sum1 = 0, sum2 = 0;
    //팀에 들어 있는 사람들 능력치 더한다.
    for (int i = 0; i < n - 1; i++) {
        for (int j = i + 1; j < n; j++) {
            if (check[i] && check[j]) sum1 += s[i][j] + s[j][i];
        }
    }
    //팀에 넣지 않은 사람들 능력치 더한다.
    for (int i = 0; i < n - 1; i++) {
        for (int j = i + 1; j < n; j++) {
            if (!check[i] && !check[j]) sum2 += s[i][j] + s[j][i];
        }
    }
    ans.push_back(abs(sum1 - sum2));
}
 
void solve(int idx, int cnt) {
    //반을 뽑았으면 능력치 계산
    if (cnt == n / 2) {
        cal();
        return;
    }
    //골라야 할 idx가 n을 초과하면 return
    if (idx == n)return;
 
    //팀에 해당 idx의 인원을 추가한다.
    check[idx] = true;
    solve(idx + 1, cnt + 1);
    //해당 idx의 인원을 추가하지 않고 넘어간다.
    check[idx] = false;
    solve(idx + 1, cnt);
}
 
int main(int argvc, char** argv) {
    cin >> n;
 
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            scanf("%d"&s[i][j]);
        }
    }
 
    solve(00);
 
    printf("%d\n"*min_element(ans.begin(), ans.end()));
 
    return 0;
}
cs

'sw 역량테스트' 카테고리의 다른 글

백준 14890 경사로  (0) 2019.04.16
백준 14503 로봇 청소기  (0) 2019.04.16
백준 14891 톱니바퀴  (0) 2019.04.12
백준 15683 감시  (0) 2019.04.12
백준 15684 사다리 조작  (0) 2019.04.12
Comments