zoukankan      html  css  js  c++  java
  • poj3249【拓扑排序】


    //题意:   给出一个有向无环图,每个顶点都有一个权值。
    //         求一条从入度为0的顶点到出度为0的顶点的一条路径,
    //         路径上所有顶点权值和最大。

    //我觉得只要明白
    //图论里的链式前向星   的  建图原理  和  拓扑排序的一点知识就完全有能力打出来

    //以后还是可以练练手的  所以写一发吧吐舌头



    //拓扑排序+优化一下
    //author keyboarder
    //time   2016/4/23 21:52
    #include <iostream>
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <algorithm>
    #include <queue>
    #include <math.h>
    #include <queue>
    #include <stack>
    using namespace std;
    #define INF 0x3f3f3f
    #define pi acos(-1.0)
    #define LL long long
    #define mm 1000000007

    #define N 1000010

    struct asd{
        int to;
        int next;
    };
    asd q[N];
    int head[N],tol;
    int pre[N];
    int out[N];
    int val[N];
    int dp[N];
    int n,m;

    void add(int a,int b)
    {
        q[tol].to=b;
        q[tol].next=head[a];
        head[a]=tol++;
    }

    void tuopu()
    {
        queue<int>e;
        while(!e.empty())
            e.pop();
        for(int i=1;i<=n;i++)
        {
            if(pre[i]==0)
            {
                pre[i]=-1;
                e.push(i);
            }
        }
        while(!e.empty())
        {
            int u=e.front();
            e.pop();
            for(int v=head[u];v!=-1;v=q[v].next)
            {
                int i=q[v].to;
                dp[i]=max(dp[u]+val[i],dp[i]);
                pre[i]--;
                if(pre[i]==0)
                {
                    pre[i]=-1;
                    e.push(i);
                }
            }
        }
    }

    int main()
    {
        while(~scanf("%d%d",&n,&m))
        {
            for(int i=1;i<=n;i++)
            {
                scanf("%d",&val[i]);
            }
            int u,v;
            tol=0;
            memset(head,-1,sizeof(head));
            memset(pre,0,sizeof(pre));
            memset(out,0,sizeof(out));
            for(int i=0;i<m;i++)
            {
                scanf("%d%d",&u,&v);
                add(u,v);
                pre[v]++;
                out[u]++;
            }
            for(int i=1;i<=n;i++)
            {
                if(pre[i]==0)
                {
                    dp[i]=val[i];
                }
                else
                    dp[i]=-INF;
            }

            tuopu();

            int ans=-INF;
            for(int i=1;i<=n;i++)
            {
                if(out[i]==0)
                    ans=max(ans,dp[i]);
            }
            printf("%d ",ans);
        }
        return 0;
    }


  • 相关阅读:
    SVN 服务器 配置
    字符串写入到json文件
    关于Linux系统打开最大文件数量
    svn clearup svn cleanup failed–previous operation has not finished; run cleanup if it was int错误的解决办法
    原标题:北大最短毕业致辞,4分钟9次掌声!
    Mysql 基础操作命令
    Git 合并两个分支内容
    微信、QQ第三方登录授权时的问题总结
    PHP CI框架数据库常用操作
    Python 抓取数据存储到Mysql中
  • 原文地址:https://www.cnblogs.com/keyboarder-zsq/p/5934564.html
Copyright © 2011-2022 走看看