• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            pku3249 Test for Job SPFA最長路

            題意這樣的:一個無向圖,一個員工從a走到b,每點都有一個權值,可能為正或者負,要求給出一條路徑,使得到b以后經過權值和最大。
            還是用神通廣大的SPFA,當求最長路來辦- -貼代碼
             1 # include <cstdio>
             2 # include <cstring>
             3 using namespace std;
             4 # define N 100005
             5 # define M 1000005
             6 # define max(a,b) ((a)>(b)?(a):(b))
             7 int g[N],v[M],nxt[M],c,val[N],q[N],s,e,n,m,id[N],od[N];
             8 int dp[N];
             9 int main()
            10 {
            11     while(scanf("%d%d",&n,&m)!=EOF)
            12     {
            13        memset(g,-1,sizeof(g));
            14        c=0;
            15        s=e=-1;
            16        memset(id,0,sizeof(id));
            17        memset(od,0,sizeof(od));
            18        for(int i=1;i<=n;i++)
            19          dp[i]=-0xfffffff;
            20        for(int i=1;i<=n;i++)
            21          scanf("%d",val+i);
            22        while(m--)
            23        {
            24           int a,b;
            25           scanf("%d%d",&a,&b);
            26           v[c]=b;
            27           nxt[c]=g[a];
            28           g[a]=c++;
            29           od[a]++;
            30           id[b]++;
            31        }
            32        for(int i=1;i<=n;i++)
            33          if(!id[i])
            34          {
            35             dp[i]=val[i];
            36             q[++e]=i;
            37          } 
            38        int res=-0xfffffff;
            39        while(s!=e)
            40        {
            41           int top=q[++s];
            42           if(!od[top])
            43              res=max(res,dp[top]);
            44           for(int p=g[top];p!=-1;p=nxt[p])
            45           {
            46               dp[v[p]]=max(dp[v[p]],dp[top]+val[v[p]]);
            47               id[v[p]]--;
            48               if(!id[v[p]])
            49                  q[++e]=v[p];
            50           }
            51        }
            52       
            53        printf("%d\n",res);
            54     }
            55     return 0;
            56 }
            57 

            posted on 2010-10-22 02:29 yzhw 閱讀(330) 評論(0)  編輯 收藏 引用 所屬分類: graph

            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            亚洲中文字幕无码久久2020| 亚洲精品无码久久一线| 国产午夜精品久久久久免费视| 久久精品天天中文字幕人妻 | 狠狠色丁香婷婷久久综合不卡| 久久中文字幕一区二区| 午夜精品久久久内射近拍高清| 99久久久精品免费观看国产| 久久久久香蕉视频| 久久久无码精品亚洲日韩京东传媒 | 久久久久亚洲AV成人网人人网站| 99麻豆久久久国产精品免费| 亚洲国产婷婷香蕉久久久久久| 久久精品草草草| 久久久精品人妻一区二区三区蜜桃| 99久久婷婷国产综合亚洲| 伊人精品久久久久7777| 国产L精品国产亚洲区久久| 久久www免费人成看片| 久久久久亚洲AV综合波多野结衣| 久久99精品久久久久久动态图| 热综合一本伊人久久精品| 久久精品国内一区二区三区| 无码伊人66久久大杳蕉网站谷歌 | 国产69精品久久久久99| 少妇精品久久久一区二区三区| 伊人色综合久久天天网| 久久无码AV中文出轨人妻| 日本久久久精品中文字幕| 97久久综合精品久久久综合| A级毛片无码久久精品免费| 久久人妻AV中文字幕| 久久精品国产亚洲av麻豆蜜芽| 亚洲日韩欧美一区久久久久我| 久久婷婷人人澡人人| 欧美精品丝袜久久久中文字幕| 欧美亚洲日本久久精品| 久久精品成人免费国产片小草| 日韩中文久久| 婷婷久久精品国产| 亚洲天堂久久久|