• <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>

            POJ 3259 Wormholes


            Bellman_Ford 算法,

            利用Bellman_Ford算法判斷是否存在負回路。如果存在負回路就一定可以回到(不停的走這個回路,直到賺到的負值夠與回去的值抵消的),如果不存在一定不可以回去。
            用cin500+ms, 用scanf  100+ms

            #include<iostream>
            #include
            <stdio.h>
            using namespace std;
            const int INF=0x0fffffff;
            struct type
            {
                   
            int s,t;
                   
            int len;
            }edge[
            30000];

            int n,m,w,nedge=0;
            int d[505];
            bool Bellman_Ford()
            {
                 
            bool isPossible=false;
                 
            for(int j=1; j<=n; j++)d[j]=INF;
                 d[
            1]=0;
                 
            int u,v;
                 
            bool f;
                 
            for(int j=1; j<=n-1; j++)
                 {
                         f
            =0;
                         
            for(int k=1; k<=nedge; k++)
                         {
                                 u
            =edge[k].s; v=edge[k].t;
                                 
            if(d[v]>d[u]+edge[k].len)
                                             d[v]
            =d[u]+edge[k].len;
                                 f
            =1;            
                         }
                         
            if(f==0)return false;
                 }
              /*前面n-1次循環可以求出無負回路時的最短路徑,再來一次如果可以更新就一定有負回路。/*
                  
            for(int k=1; k<=nedge; k++)
                         {
                                 u
            =edge[k].s; v=edge[k].t;
                                 
            if(d[v]>d[u]+edge[k].len)
                                       {  d[v]
            =d[u]+edge[k].len; return 1;}
                                            
                         }
                 
                
            // system("pause");
                 return 0;
                 
            }

            int main()
            {
                
            int t;
                cin
            >>t;
                
            while(t--)
                {
                          
            int i,j,u,v,value;
                          scanf(
            "%d %d %d",&n,&m,&w);//cin>>n>>m>>w;
                          nedge=0;
                          
            for(int i=1; i<=m; i++)
                          {
                                  scanf(
            "%d %d %d",&u,&v,&value);//cin>>u>>v>>value;
                                  ++nedge;
                                  edge[nedge].s
            =u;
                                  edge[nedge].t
            =v;
                                  edge[nedge].len
            =value;
                                  
            ++nedge;
                                  edge[nedge].s
            =v;
                                  edge[nedge].t
            =u;
                                  edge[nedge].len
            =value;
                          }     
                              
                          
            for(int i=1; i<=w; i++)
                          {
                                  scanf(
            "%d %d %d",&u,&v,&value);//cin>>u>>v>>value;
                                  ++nedge;
                                  edge[nedge].s
            =u;
                                  edge[nedge].t
            =v;
                                  edge[nedge].len
            =-value;
                                  
                                 
            /* ++nedge;
                                  edge[nedge].s=v;
                                  edge[nedge].t=u;
                                  edge[nedge].len=-value;
                                  
            */
                          }
                          
                          
            if(Bellman_Ford())
                                     cout
            <<"YES"<<endl;
                          
            else       cout<<"NO"<<endl;
                 
                }
                system(
            "pause");
                
            return 0;
            }

            posted on 2010-08-09 19:38 田兵 閱讀(723) 評論(0)  編輯 收藏 引用 所屬分類: POJ

            <2010年8月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導航

            統計

            常用鏈接

            留言簿(2)

            隨筆分類(65)

            隨筆檔案(65)

            文章檔案(2)

            ACM

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            色综合久久综合中文综合网| 理论片午午伦夜理片久久 | 精品国产91久久久久久久a| 中文字幕亚洲综合久久2| 欧美日韩成人精品久久久免费看| 色天使久久综合网天天| 亚洲精品乱码久久久久久自慰| 久久ZYZ资源站无码中文动漫| 久久www免费人成看国产片| 国产精品久久婷婷六月丁香| MM131亚洲国产美女久久| 亚洲精品久久久www| 欧美亚洲国产精品久久蜜芽| 国内精品久久久久影院薰衣草 | 久久久99精品成人片中文字幕 | 国产精品欧美亚洲韩国日本久久 | 亚洲午夜精品久久久久久人妖| 亚洲国产成人精品91久久久 | 国产精品国色综合久久| 久久久久99精品成人片牛牛影视| 久久精品国产亚洲AV香蕉| 中文字幕无码久久精品青草| 国产亚洲精午夜久久久久久| 99久久精品日本一区二区免费| 色妞色综合久久夜夜| 欧美激情精品久久久久久| 狠狠精品干练久久久无码中文字幕 | 亚洲国产成人久久一区久久| 久久本道久久综合伊人| 国产成人香蕉久久久久| 国产99久久久国产精免费| 国产成人精品久久二区二区| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 亚洲国产成人久久笫一页| 久久影院亚洲一区| 欧美粉嫩小泬久久久久久久| 亚州日韩精品专区久久久| 97精品伊人久久大香线蕉| 亚洲国产精品无码久久一线 | 久久无码专区国产精品发布| 天堂无码久久综合东京热|