1949 우수마을


1. 1번마을이 우수마을인지, 아닌지 두가지경우로 나눈다.


2. 1번에 인접된 모든 마을에 대하여 max함수를 통해 최대값을 찾는다.


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
#include <stdio.h>
#include <vector>
#include <algorithm>
#define ll long long
using namespace std;
 
int n;
int price[10001];
bool visited[10001];
vector<int> map[10001];
 
ll dfs(int v, bool flag) {
    int ans = 0;
    visited[v] = true;
 
    for (int i = 0; i < map[v].size(); i++) {
        int next = map[v][i]; //다음 마을
        if (visited[next]) continue//이미 방문했으면 continue
        //현재마을이 우수마을인 경우
        if (flag) {
            ans += dfs(next, 0);
        }
        //현재마을이 우수마을이 아닌 경우
        else {
            ans += max(dfs(next, 0), dfs(next, 1+ price[next]);
        }
    }
 
    visited[v] = false;
    return ans;
}
 
int main() {
    scanf("%d"&n);
    for (int i = 1; i <= n; i++)
        scanf("%d"&price[i]);
    n--;
 
    while (n--) {
        int x, y;
        scanf("%d %d"&x, &y);
        map[x].push_back(y);
        map[y].push_back(x);
    }
 
    printf("%lld\n", max(dfs(10), dfs(11+ price[1]));
}
cs


'BOJ::문제풀이' 카테고리의 다른 글

1764 듣보잡  (0) 2018.02.24
9663 N-Queen  (0) 2018.02.24
3190 뱀  (1) 2018.02.21
14612 김식당  (0) 2018.02.17
2468 안전영역  (0) 2018.02.17

+ Recent posts