码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 3249 Test for Job 拓扑排序+DP

时间:2014-08-05 00:05:48      阅读:275      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   io   数据   for   问题   

http://poj.org/problem?id=3249

题意:

给一个有向无环图DAG(不一定联通),每个点有权值,入度为0的点为起点,出度为0的点为终点,选择一个起点走到一个终点,使得路上的权和最大。

分析:

dp[to] = max(dp[from]) + value[to],然后先拓扑排序保证状态正确转移即可,终点做标记,如果是终点则尝试更新答案。

update:因为点权可以为负,所以程序里用dp[i] == -1表示未访问过该点是有问题的,不过没有遇上会卡掉这种情况的数据=。=

 

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<algorithm>
 4 #include<queue>
 5 using namespace std;
 6 
 7 int n, m, esize, x, y;
 8 int a[100100], en[100100], in[100100], bfn[100100], dp[100100];
 9 bool ed[100100];
10 struct edge{
11     int v, n;
12 } e[1000100];
13 void addedge(int u, int v)
14 {
15     e[esize].v = v;;
16     e[esize].n = en[u];
17     en[u] = esize ++;
18 }
19 queue<int> q;
20 int main()
21 {
22     while(scanf("%d%d", &n, &m) != EOF)
23     {
24         for (int i = 1; i <= n; i++)
25             scanf("%d", a+i);
26         memset(en, -1, sizeof(en));
27         memset(in, 0, sizeof(0));
28         memset(ed, true, sizeof(ed));
29         esize = 0;
30         for (int i = 0; i < m; i++){
31             scanf("%d %d", &x, &y);
32             addedge(x, y);
33             in[y]++;
34             ed[x] = 0;
35         }
36         for (int i = 1; i <= n; i++)
37             if (!in[i]) q.push(i);
38         int ans = -2147483640;
39         int cnt = 0;
40         while(!q.empty())
41         {
42             int u = q.front(); q.pop();
43             bfn[cnt++] = u;
44             for (int t = en[u]; t != -1; t = e[t].n){
45                 int v = e[t].v;
46                 in[v] --;
47                 if (in[v] == 0)    q.push(v);
48             }
49         }
50         memset(dp, -1, sizeof(dp));
51         for (int i = 0; i < n; i++){
52             int u = bfn[i];
53             if (dp[u] == -1) dp[u] = a[u];
54             if (ed[u]) ans = max(ans, dp[u]);
55             for (int t = en[u]; t != -1; t = e[t].n){
56                 int v = e[t].v;
57                 if (dp[v] == -1 || dp[v] < dp[u] + a[v])
58                     dp[v] = dp[u] + a[v];
59             }
60         }
61         printf("%d\n", ans);
62     }
63     return 0;
64 }

 

POJ 3249 Test for Job 拓扑排序+DP,布布扣,bubuko.com

POJ 3249 Test for Job 拓扑排序+DP

标签:style   blog   http   color   io   数据   for   问题   

原文地址:http://www.cnblogs.com/james47/p/3891001.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!