洛谷P2996 [USACO10NOV]拜訪奶牛Visiting Cows

題目node

樹形dpios

設f[i][j]表示走到第i號節點的最大權值git

j爲0/1表示這個點選或者不選spa

若是這個點不選 就從他的子樹裏的選或者不選選最大code

若是這個點選 就加上他子樹的不選blog

f[x][0] += max(f[to][1], f[to][0]);get

f[x][1] += f[to][0];it

注意第二維要開到2io

Code:class

//設f[i][j]表示選到第i號節點的最大權值 
#include <cstdio>
#include <iostream>
using namespace std;
const int N = 500010;
int f[N][2], n, head[N << 1], cnt;
struct node {
    int nxt, to;
}e[N];
int read() {
    int s = 0, w = 1;
    char ch = getchar();
    while(!isdigit(ch)) {if(ch == '-') w = -1; ch = getchar();}
    while(isdigit(ch)) {s = s * 10 + ch - '0'; ch = getchar();}
    return s * w;
}
void add(int x, int y) {
    e[++cnt].nxt = head[x];
    e[cnt].to = y;
    head[x] = cnt;
}
void dfs(int x, int fa) {
    f[x][1] = 1;
    for(int i = head[x]; i; i = e[i].nxt) {
        int v = e[i].to;
        if(v != fa) {
            dfs(v, x);
            f[x][0] += max(f[v][0], f[v][1]);
            f[x][1] += f[v][0];    
        } 
    }
}
int main() {
    n = read();
    for(int i = 1, x, y; i < n; i++) {
        x = read(), y = read();
        add(x, y), add(y, x);
    }
    dfs(1, 0);
    cout << max(f[1][1], f[1][0]) << endl;
    return 0;
}
相關文章
相關標籤/搜索