麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

樹形DP

2019-11-10 20:41:22
字體:
來源:轉載
供稿:網友

樹的重心POJ 1655樹的最長路徑最遠點對POJ 1985樹的最大獨立集POJ 2342

樹的重心

對于一棵n個結點的無根樹,找到一個點,使得把樹變成以該點為根的有根樹時,最大子樹的結點數最小,該點即為重心。換句話說,刪除這個點后最大連通塊(一定是樹)的結點數最小。

POJ 1655

一道典型的求樹的重心的題目,用dfs實現 用數組dp[i]記錄i的最大子樹的大小,son[i]記錄兒子的個數 樹的重心即為所有節點中最大子樹大小最小的節點

#include <iostream>#include <cstdio>#include <algorithm>#include <cstring>#define L 20010using namespace std;struct node{ int nxt, to;} a[L << 1];int n, T, u, v, head[L], cnt, son[L], siz, ans, dp[L];inline void add(int x, int y) { a[++cnt].nxt = head[x]; a[cnt].to = y; head[x] = cnt;}inline void dfs(int s, int fa) { dp[s] = 0, son[s] = 1; for (int i = head[s]; i; i = a[i].nxt) { int u = a[i].to; if (u == fa) continue; dfs(u, s); dp[s] = max(dp[s], son[u]); son[s] += son[u]; } dp[s] = max(dp[s], n - son[s]);}int main() { scanf("%d", &T); while (T--) { memset(a, 0, sizeof(a)); memset(head, 0, sizeof(head)); memset(dp, 0, sizeof(dp)); memset(son, 0, sizeof(son)); cnt = 0; scanf("%d", &n); for (int i = 1; i < n; ++i) { scanf("%d %d", &u, &v); add(u, v), add(v, u); } dfs(1, 0); ans = 1, siz = dp[1]; for (int i = 2; i <= n; ++i) if (dp[i] < siz) ans = i, siz = dp[i]; 樹的最長路徑(最遠點對)

POJ 1985

樹形DP的板子題 不斷dfs更新出以每個點為根節點最遠及次遠的長度,輸出長度和的最大值即可

#include <iostream>#include <cstdio>#include <algorithm>#include <cstring>#define L 1000010using namespace std;struct node{ int nxt, to; long long l;} e[L];int n, m, a, b, head[L], cnt;long long c, dp1[L], dp2[L], ans;char pd[3];inline void add(int a, int b, long long d) { e[++cnt].nxt = head[a]; e[cnt].to = b; e[cnt].l = d; head[a] = cnt;}inline void dfs(int x, int fa) { for (int i = head[x]; i; i = e[i].nxt) { int u = e[i].to; if (u == fa) continue; dfs(u, x); if (dp1[x] < dp1[u] + e[i].l) dp2[x] = dp1[x], dp1[x] = dp1[u] + e[i].l; else dp2[x] = max(dp2[x], dp1[u] + e[i].l); } ans = max(ans, dp1[x] + dp2[x]);}int main() { scanf("%d %d", &n, &m); for (int i = 1; i <= m; ++i) { scanf("%d %d %lld %s", &a, &b, &c, pd); add(a, b, c), add(b, a, c); } dfs(1, 0); printf("%lld/n", ans); return 0;}

樹的最大獨立集

POJ 2342

對于每一個節點有兩種情況,去或者不去,可用二維狀態表示 若i去了,則i的兒子不能去,dfs更新值即可

#include <iostream>#include <cstdio>#include <algorithm>#include <cstring>#define L 6000 + 10using namespace std;int n, a, b, root, fa[L], vis[L], dp[L][2];inline void dfs(int x) { vis[x] = 1; for (int i = 1; i <= n; ++i) if (fa[i] == x && !vis[i]) { dfs(i); dp[x][1] += dp[i][0]; dp[x][0] += max(dp[i][1], dp[i][0]); }}int main() { while (scanf("%d", &n) == 1){ for (int i = 1; i <= n; ++i) scanf("%d", &dp[i][1]); root = 0; while(scanf("%d %d", &a, &b) && a && b) fa[a] = b, root = b; memset(vis, 0, sizeof(vis)); dfs(root); printf("%d/n", max(dp[root][1], dp[root][0])); } return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩黄在线观看 | 亚洲天堂在线电影 | 成人一级黄色 | 国产成人高潮免费观看精品 | 天天操天天看 | 国产一级桃视频播放 | 青青青在线免费 | 亚洲成年人免费网站 | 欧美一级黄色免费看 | 婷婷中文字幕一区二区三区 | 欧美日韩亚洲精品一区二区三区 | 国产精品久久久久影院老司 | 久久久av亚洲男天堂 | 国产午夜免费福利 | 一级尻逼视频 | 美女露100%无遮挡 | 黄色影院在线看 | 国产精品亚洲精品久久 | 中文字幕在线亚洲精品 | 毛片一级片 | 91短视频在线视频 | 日韩精品久久久久久久九岛 | 午夜视频在线看 | 49vvv| 国产做爰 | 欧美成人影院 | 免费一级毛片免费播放 | 欧美日韩电影在线 | 巨乳激情| 亚洲91精品| 精品一区二区免费 | 高清国产福利 | 日本中文一级片 | 欧美乱论| 日本一区二区三区视频在线 | 欧美18—19sex性护士中国 | 操操日日 | 欧美日韩在线播放 | 国产外围在线 | 圆产精品久久久久久久久久久 | www.成人在线 |