日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > 綜合技術 > hdu1520 樹形dp

hdu1520 樹形dp

來源:程序員人生   發布時間:2015-05-29 08:27:54 閱讀次數:2722次

每一個節點有權值,子節點和父節點不能同時選,問最后能選的最大價值是多少?


#include<cstdio> #include<algorithm> #include<vector> #include<queue> #include<cmath> #include<cstring> using namespace std; typedef long long int64; const int INF = 0x3f3f3f3f; const double PI = acos(⑴.0); const int MAXN = 6010; vector<int>adj[MAXN]; int indeg[MAXN]; int val[MAXN]; int f[MAXN][2]; int n, m; void dfs(int u){ f[u][0] = 0; f[u][1] = val[u]; for(int i=0; i<adj[u].size(); ++i){ int v = adj[u][i]; // if(vis[v]) continue; dfs(v); f[u][0] += max(f[v][1], f[v][0]); f[u][1] += f[v][0]; } } int main(){ while(~scanf("%d", &n) && n){ for(int i=1; i<=n; ++i) adj[i].clear(); for(int i=1; i<=n; ++i) scanf("%d", &val[i]); memset(indeg, 0, sizeof(indeg)); int u, v; while(~scanf("%d%d", &v, &u) && v+u){ adj[u].push_back(v); ++indeg[v]; } memset(f, 0, sizeof(f)); for(int i=1; i<=n; ++i)if(!indeg[i]){ dfs(i); printf("%d ", max(f[i][0], f[i][1])); break; } } return 0; }


生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 人人澡人人爽 | 中文字幕不卡一区 | 天堂在线中文 | 精品福利一区二区三区 | 午夜精品久久久久久久久久久 | 国产一区二区在线免费视频 | 日本视频免费 | 国产精品久久久久久久9999 | 久久九九亚洲 | 日韩国产a | 欧美.com | 国产精品一区二区在线看 | 成人免费网站在线观看 | 日韩在线精品视频 | 一区二区三区久久久 | 日韩三级一区 | 色婷婷综合久久久久中文一区二 | 欧美一区二区三区四区不卡 | 国内外成人在线视频 | 欧美爱爱网| 成人欧美一区二区三区黑人孕妇 | 三区av | 九九热久久免费视频 | 99久久精品国产毛片 | 成人污视频在线观看 | 国产精品一区二区久久久 | 欧美成人精品在线 | 日韩精品在线视频 | 国产特级片 | 久久99亚洲精品 | 日皮视频免费观看 | 亚洲精品麻豆 | 国产69精品久久久久777 | 三级国产在线观看 | 成年人视频免费在线观看 | 日本精品专区 | 国产精品久久久久久福利一牛影视 | 高清二区| 国产精品久久久久一区二区三区 | 国产成人精品免费 | 日韩在线中文字幕 |