青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

pku 2762 Going from u to v or from v to u? 強聯(lián)通分支縮點+找最長鏈

題意是這樣:一個有向圖,問能否取任意兩個不同的節(jié)點u,v,u->v或者v->u存在路徑。
首先還是縮點,因為強聯(lián)通分量里肯定任意兩點可達(dá)的。縮點后,圖變成DAG
下面就到了關(guān)鍵的部分了,什么情況下u、v互相不可達(dá)呢?顯然,u,v在兩條不同的鏈上。
然后就很簡單了,找最長鏈也可意,拓?fù)渑判蚺袛嘈蛄形ㄒ恍砸部梢浴N沂前春笳咦龅摹?br>
  1 import java.io.*;
  2 import java.util.Arrays;
  3 import java.util.LinkedList;
  4 public class Main {
  5 
  6     /**
  7      * @param args
  8      */
  9 
 10     static int g[]=new int[1001],ng[]=new int [1001],bid[]=new int[1001],stack[]=new int[1001],top;
 11     static int v[]=new int[12005],nxt[]=new int[12005],c,n,m;
 12     static int low[]=new int[1001],cnt,bc;
 13     static int degree[]=new int[1001];
 14     static LinkedList<Integer> q=new LinkedList<Integer>();
 15     static void tarjan(int pos)
 16     {
 17         int nowid=cnt++;
 18         low[pos]=nowid;
 19         stack[++top]=pos;
 20         for(int p=g[pos];p!=-1;p=nxt[p])
 21         {
 22             if(low[v[p]]==-1)
 23                 tarjan(v[p]);
 24             low[pos]=Math.min(low[pos],low[v[p]]);
 25         }
 26         if(low[pos]>=nowid)
 27         {
 28             do
 29             {
 30                 bid[stack[top]]=bc;
 31                 low[stack[top]]=Integer.MAX_VALUE;
 32             }while(stack[top--]!=pos);
 33             bc++;
 34         }
 35     }
 36     static void dfs(int pos)
 37     {
 38         low[pos]=1;
 39         stack[bid[pos]]=1;
 40         for(int p=g[pos];p!=-1;p=nxt[p])
 41             if(low[v[p]]==-1)
 42                 dfs(v[p]);
 43     }
 44     public static void main(String[] args) throws IOException{
 45         StreamTokenizer in=new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
 46         int testcase;
 47         in.nextToken();
 48         testcase=(int)in.nval;
 49         while((testcase--)!=0)
 50         {
 51             int a,b;
 52             in.nextToken();
 53             n=(int)in.nval;
 54             in.nextToken();
 55             m=(int)in.nval;
 56             Arrays.fill(g, -1);
 57             c=0;
 58             while((m--)!=0)
 59             {
 60                 in.nextToken();
 61                 a=(int)in.nval;
 62                 in.nextToken();
 63                 b=(int)in.nval;
 64                 v[c]=b;
 65                 nxt[c]=g[a];
 66                 g[a]=c++;
 67             }
 68             Arrays.fill(low,-1);
 69             Arrays.fill(bid,-1);
 70             cnt=bc=0;
 71             top=-1;
 72             for(int i=1;i<=n;i++)
 73                if(low[i]==-1)
 74                     tarjan(i);
 75             Arrays.fill(ng,-1);
 76             for(int i=1;i<=n;i++)
 77                 for(int p=g[i];p!=-1;p=nxt[p])
 78                     if(bid[v[p]]!=bid[i])
 79                     {
 80                         v[c]=bid[v[p]];
 81                         nxt[c]=ng[bid[i]];
 82                         ng[bid[i]]=c++;
 83                     }
 84             q.clear();
 85             Arrays.fill(degree,0);
 86             for(int i=0;i<bc;i++)
 87                 for(int p=ng[i];p!=-1;p=nxt[p])
 88                     degree[v[p]]++;
 89             for(int i=0;i<bc;i++)
 90                 if(degree[i]==0)
 91                     q.add(i);
 92             int count=0;
 93             while(!q.isEmpty()&&q.size()<=1)
 94             {
 95                 int top=q.poll();
 96                 count++;
 97                 for(int p=ng[top];p!=-1;p=nxt[p])
 98                     if(true)
 99                     {
100                         degree[v[p]]--;
101                         if(degree[v[p]]==0)
102                             q.add(v[p]);
103                     }
104             }
105             if(q.isEmpty()&&count==bc)
106                System.out.println("Yes");
107             else
108                 System.out.println("No");
109             
110         }
111                     
112     }
113 
114 }
115 


posted on 2010-10-26 00:04 yzhw 閱讀(144) 評論(0)  編輯 收藏 引用 所屬分類: graph

<2010年11月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導(dǎo)航

統(tǒng)計

公告

統(tǒng)計系統(tǒng)

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品国产三级国产专播品爱网| 国产在线国偷精品产拍免费yy| 欧美日韩一区二区三区在线看| 一本色道久久88综合日韩精品 | 国产精品久久久久久久久搜平片 | 欧美精品尤物在线| 欧美 亚欧 日韩视频在线| 中文网丁香综合网| 国产精品日韩电影| 久久中文在线| 亚洲天堂第二页| 欧美一区二区三区精品电影| 性欧美大战久久久久久久免费观看| 国产区在线观看成人精品| 亚洲精华国产欧美| 午夜影视日本亚洲欧洲精品| 久久婷婷丁香| 性色av香蕉一区二区| 在线一区二区三区做爰视频网站| 在线亚洲欧美视频| 一区二区成人精品| 亚洲三级性片| 亚洲欧美日韩视频一区| 欧美日韩综合在线| 欧美午夜一区二区福利视频| 好吊色欧美一区二区三区视频| 黑人一区二区三区四区五区| 一区二区三区亚洲| 国模精品一区二区三区| 国内久久婷婷综合| 亚洲精品一级| 老司机一区二区三区| 亚洲福利视频网| 亚洲七七久久综合桃花剧情介绍| 欧美亚洲免费高清在线观看| 久久久亚洲人| 欧美视频在线免费看| 最近中文字幕mv在线一区二区三区四区| 亚洲大片在线| 日韩一二三在线视频播| 欧美在线影院在线视频| 亚洲电影观看| 久久视频国产精品免费视频在线| 欧美伦理影院| 激情欧美一区| 久久久精品一区| 99www免费人成精品| 欧美一区在线视频| 国产欧美日韩精品一区| 亚洲美女视频| 久久这里有精品15一区二区三区| 亚洲欧美日韩天堂一区二区| 欧美成人一区二区三区| 欧美国产日韩二区| 亚洲国产视频直播| 久久精品国产免费看久久精品| 在线视频免费在线观看一区二区| 久久久国产精品亚洲一区 | 狠狠色香婷婷久久亚洲精品| 亚洲欧美在线高清| 亚洲精品国产系列| 久久先锋资源| 欧美日韩亚洲系列| 美女精品在线观看| 国产综合在线视频| 亚洲一区日韩在线| 亚洲电影免费观看高清完整版| 久久人人精品| 国内精品久久久久久久影视蜜臀 | 午夜伦欧美伦电影理论片| 欧美成人精品1314www| 国产一区二区三区四区| 午夜精品视频一区| 亚洲精品视频在线看| 老司机免费视频久久| 精品福利av| 亚洲国产成人高清精品| 美女视频黄a大片欧美| 在线观看成人av| 亚洲激情电影中文字幕| 久久精品一级爱片| 一区二区av在线| 国产乱码精品1区2区3区| 亚洲一区久久| 欧美在线免费| 亚洲成人在线免费| 欧美福利视频网站| 欧美视频中文字幕| 午夜视频久久久| 亚洲欧美资源在线| 亚洲麻豆av| 99视频精品在线| 国产精品欧美精品| 免费一区二区三区| 欧美激情黄色片| 国产主播精品在线| 亚洲免费电影在线| 国产精品视频精品视频| 裸体一区二区三区| 欧美日韩国产一区二区三区| 欧美精品二区| 欧美二区视频| 午夜免费在线观看精品视频| 欧美在线高清| 国产视频一区欧美| 亚洲欧洲一区二区三区在线观看| 欧美日韩在线电影| 亚洲欧洲三级电影| 性欧美办公室18xxxxhd| 91久久久久久久久久久久久| 亚洲小说春色综合另类电影| 亚洲欧美国产三级| 国产一区二区三区奇米久涩 | 亚洲欧美另类久久久精品2019| 亚洲校园激情| 一本一本久久| 激情综合久久| 亚洲人精品午夜| 国产农村妇女毛片精品久久莱园子 | 欧美日韩在线视频观看| 欧美成人首页| 欧美午夜精品久久久久久久| 久久久视频精品| 国产日韩欧美91| 亚洲欧洲一区二区三区久久| 国产免费观看久久| 亚洲夜晚福利在线观看| 亚洲人成绝费网站色www| 亚洲一区二区三区四区五区午夜 | 日韩视频一区| 一本色道久久综合亚洲精品不卡| 久久成人免费| 亚洲欧美日韩一区二区在线| 欧美日韩一区二区国产| 欧美激情久久久| 国内揄拍国内精品久久| 久久精品2019中文字幕| 性做久久久久久久久| 欧美猛交免费看| 日韩一级在线观看| 亚洲精品乱码视频| 久久视频在线免费观看| 欧美韩日视频| 伊人久久大香线蕉综合热线 | 亚洲欧美春色| 久久久久久9| 国产欧美日韩综合| 亚洲一区二区影院| 久久九九电影| 国内精品久久久久国产盗摄免费观看完整版| 一本色道久久| 欧美在线播放高清精品| 国产精品一级在线| 亚洲先锋成人| 久久麻豆一区二区| 精品999在线观看| 久久久久国产精品一区| 亚洲国产另类久久久精品极度| 亚洲国产天堂久久综合| 在线精品视频一区二区| 欧美一区二区网站| 国产日产高清欧美一区二区三区| 亚洲欧美中文另类| 欧美 日韩 国产在线| 一区二区三区|亚洲午夜| 国产精品尤物| 免费av成人在线| 亚洲一区二区网站| 欧美国产日韩在线| 欧美美女bb生活片| 精品999成人| 欧美激情一区二区久久久| 亚洲视频欧美在线| 美女精品自拍一二三四| 一区二区三区四区国产精品| 国产一区二区精品久久91| 欧美激情第三页| 久久www成人_看片免费不卡| 日韩视频一区二区三区在线播放| 久久精品五月| 亚洲一区二区三区精品视频| 亚洲国产福利在线| 国产精品免费视频xxxx| 欧美国产日韩免费| 久久久午夜视频| 午夜在线电影亚洲一区| 99国产精品私拍| 亚洲国内自拍| 免费观看亚洲视频大全| 久久国产精品一区二区| 亚洲自拍偷拍视频| 9人人澡人人爽人人精品| 91久久黄色| 在线观看欧美日韩国产| 国产视频综合在线| 国产精品综合视频| 国产精品男人爽免费视频1| 欧美日韩你懂的| 欧美精品一区二区三区蜜臀| 免费观看成人www动漫视频|