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

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>
            亚洲黄色在线视频| 制服诱惑一区二区| 亚洲国产成人av好男人在线观看| 欧美另类女人| 国内在线观看一区二区三区| 国产在线精品一区二区夜色| 久久亚洲风情| 中文一区在线| 亚洲国产精品一区二区久| 狠狠做深爱婷婷久久综合一区| 久久电影一区| 欧美.www| 欧美怡红院视频| 一本一本久久| 亚洲人成7777| 亚洲电影免费观看高清| 国产精品视频久久一区| 欧美成人午夜激情在线| 久久综合免费视频影院| 久久成人国产精品| 午夜精品视频网站| 欧美一级专区| 久久久久久久一区二区三区| 久久人人看视频| 久久精品噜噜噜成人av农村| 99精品久久久| 欧美在线地址| 亚洲电影欧美电影有声小说| 亚洲精美视频| 六十路精品视频| 久久久久国产一区二区| 欧美在线在线| 亚洲精品久久久久久下一站 | 欧美日韩免费在线| 国产亚洲午夜| 久久精品在线视频| 亚洲在线观看视频| 久久精品国产999大香线蕉| 亚洲乱码一区二区| 欧美日韩麻豆| 亚洲激情另类| 日韩一级免费观看| 国产伦精品一区二区三区四区免费| 亚洲欧美美女| 久久成人免费日本黄色| 伊人久久婷婷色综合98网| 日韩一级免费| 欧美激情第一页xxx| 亚久久调教视频| 国产精品一卡二卡| 亚洲欧美激情一区| 99精品免费视频| 欧美日韩在线免费观看| 亚洲精品三级| 亚洲高清激情| 裸体丰满少妇做受久久99精品 | 久久av一区二区三区漫画| 欧美日韩视频在线一区二区| 亚洲另类在线一区| 亚洲国产精品电影| 老司机免费视频一区二区| 韩国av一区二区三区| 欧美亚洲在线| 亚洲男人av电影| 国产日韩在线看片| 久久尤物视频| 免费国产一区二区| 91久久精品国产91久久| 欧美高清视频一二三区| 欧美xx视频| 亚洲免费观看高清在线观看 | 久久婷婷久久| 精品999久久久| 老司机午夜免费精品视频| 久久久国际精品| 亚洲黑丝一区二区| 亚洲精品五月天| 国产精品成av人在线视午夜片| 亚洲一区在线播放| 先锋影院在线亚洲| 国产综合久久久久影院| 欧美黄色日本| 欧美激情一区二区| 午夜精品一区二区三区在线视| 亚洲小说欧美另类婷婷| 国内精品伊人久久久久av一坑| 久久一区二区三区四区五区| 免费在线视频一区| 午夜久久资源| 久久精品国产99国产精品澳门| 亚洲日本中文字幕区| 日韩视频中午一区| 国产亚洲人成a一在线v站| 欧美freesex8一10精品| 欧美日韩视频在线一区二区| 久久久999精品免费| 欧美日本精品在线| 欧美在线观看天堂一区二区三区| 久久久久久久性| 亚洲制服欧美中文字幕中文字幕| 欧美在线免费看| 在线一区二区三区做爰视频网站| 午夜精品一区二区三区在线视| 亚洲精品韩国| 欧美综合国产精品久久丁香| 亚洲精品系列| 久久av红桃一区二区小说| 中文日韩电影网站| 久久久久久久久久看片| 午夜精品国产精品大乳美女| 蜜桃久久精品一区二区| 久久久久www| 国产精品久久久久久久久久免费看| 亚洲成色777777在线观看影院| 国产精品老女人精品视频| 亚洲日本va午夜在线影院| 日韩亚洲欧美中文三级| 亚洲国产中文字幕在线观看| 午夜一级久久| 欧美一级成年大片在线观看| 欧美美女福利视频| 欧美国产日本韩| 国内精品国产成人| 午夜久久久久久| 亚洲欧美影院| 国产精品二区二区三区| 亚洲人成亚洲人成在线观看| 亚洲国产黄色片| 久久久国产亚洲精品| 久久这里只有| 国产一区视频网站| 新67194成人永久网站| 亚洲欧美日本日韩| 国产精品www994| 日韩视频在线一区二区三区| 国产精品久久久久一区二区三区| 久久精品人人做人人爽| 国产精品九九久久久久久久| 亚洲另类视频| 一本大道久久a久久精品综合| 麻豆精品91| 欧美国产日本| 一本到12不卡视频在线dvd| 欧美v日韩v国产v| 欧美a级一区| 亚洲精品一区久久久久久| 欧美福利在线观看| 亚洲国产导航| 夜夜爽www精品| 欧美日韩天堂| 亚洲自拍偷拍一区| 久久精品一二三区| 亚洲国产精品黑人久久久| 欧美**字幕| 一区二区三区色| 性娇小13――14欧美| 黄色成人av| 欧美va亚洲va香蕉在线| 中国成人亚色综合网站| 欧美自拍偷拍| 亚洲国产精品ⅴa在线观看| 欧美精品1区2区| 亚洲一级电影| 久久久综合视频| 日韩视频免费观看| 国产精品高潮呻吟视频| 久久精品国产欧美亚洲人人爽| 美女精品国产| 亚洲一区二区三区三| 国产亚洲毛片在线| 欧美伦理在线观看| 亚洲欧美影院| 91久久在线播放| 性一交一乱一区二区洋洋av| 亚洲国产视频一区| 国产精品福利片| 你懂的网址国产 欧美| 亚洲天堂av在线免费观看| 欧美成人蜜桃| 香蕉免费一区二区三区在线观看 | 午夜一区不卡| 亚洲另类自拍| 欧美成人自拍视频| 久久国产精品一区二区三区| 亚洲综合色自拍一区| 亚洲国产aⅴ天堂久久| 欧美在线91| 亚洲一区中文| 亚洲三级免费观看| 国户精品久久久久久久久久久不卡| 欧美精品一区二区高清在线观看| 欧美一区二区三区精品电影| 亚洲看片免费| 欧美ed2k| 久久五月天婷婷| 欧美一级大片在线观看| 亚洲一区二区高清视频| 亚洲日本激情| 亚洲精品一区二区三区福利| 国内免费精品永久在线视频|