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

獨立博客: 哲學與程序

哲學與程序

混合圖歐拉路例題 ZOJ1992

本文轉載至哲學與程序博客:http://zhexue.sinaapp.com/?p=105

題目來源:ZOJ1992

對于一個混合圖,即有有向邊又有無向邊的圖,判斷是否存在一條歐拉回路。
解法(轉):混合圖歐拉回路用的是網絡流。把該圖的無向邊隨便定向,計算每個點的入度和出度。如果有某個點出入度之差為奇數,那么肯定不存在歐拉回路。因為歐拉回路要求每點入度 = 出度,也就是總度數為偶數,存在奇數度點必不能有歐拉回路?,F在每個點入度和出度之差均為偶數。將這個偶數除以2,得x。即是說,對于每一個點,只要將x條邊反向(入>出就是變入,出>入就是變出),就能保證出 = 入。如果每個點都是出 = 入,那么很明顯,該圖就存在歐拉回路。現在的問題就變成了:該改變哪些邊,可以讓每個點出 = 入?構造網絡流模型。有向邊不能改變方向,直接刪掉。開始已定向的無向邊,定的是什么向,就把網絡構建成什么樣,邊長容量上限1。另新建s和t。對于入 > 出的點u,連接邊(u, t)、容量為x,對于出 > 入的點v,連接邊(s, v),容量為x(注意對不同的點x不同。當初由于不小心,在這里錯了好幾次)。之后,察看是否有滿流的分配。有就是能有歐拉回路,沒有就是沒有。查看流值分配,將所有流量非 0(上限是1,流值不是0就是1)的邊反向,就能得到每點入度 = 出度的歐拉圖。由于是滿流,所以每個入 > 出的點,都有x條邊進來,將這些進來的邊反向,OK,入 = 出了。對于出 > 入的點亦然。那么,沒和s、t連接的點怎么辦?和s連接的條件是出 > 入,和t連接的條件是入 > 出,那么這個既沒和s也沒和t連接的點,自然早在開始就已經滿足入 = 出了。那么在網絡流過程中,這些點屬于“中間點”。我們知道中間點流量不允許有累積的,這樣,進去多少就出來多少,反向之后,自然仍保持平衡。所以,就這樣,混合圖歐拉回路問題,解了。 

#include<stdio.h>
#include
<math.h>
#include
<algorithm>
#include
<string.h>
using namespace std;
#define N 205
#define MAXN N
#define inf 100000000
int map[N][N];
int flow[N][N];
int max_flow(int n,int mat[][MAXN],int source,int sink,int flow[][MAXN]){ 
   
int pre[MAXN],que[MAXN],d[MAXN],p,q,t,i,j; 
   
if (source==sink) return inf; 
   
for (i=0;i<n;i++
       
for (j=0;j<n;flow[i][j++]=0); 
   
for (;;){ 
       
for (i=0;i<n;pre[i++]=0); 
        pre[t
=source]=source+1,d[t]=inf; 
       
for (p=q=0;p<=q&&!pre[sink];t=que[p++]) 
              
for (i=0;i<n;i++
               
if (!pre[i]&&(j=mat[t][i]-flow[t][i])) 
                     pre[que[q
++]=i]=t+1,d[i]=d[t]<j?d[t]:j; 
               
else if (!pre[i]&&(j=flow[i][t])) 
                 pre[que[q
++]=i]=-t-1,d[i]=d[t]<j?d[t]:j; 
       
if (!pre[sink]) break
       
for (i=sink;i!=source;) 
              
if (pre[i]>0
                flow[pre[i]
-1][i]+=d[sink],i=pre[i]-1
              
else 
                flow[i][
-pre[i]-1]-=d[sink],i=-pre[i]-1
    } 
   
for (i=0;i<n;i++)
       
if(mat[source][i] > flow[source][i])
           
return 0;
   
return 1
}
int main()
{
   
int T, degin[N],degout[N], n, m, x, y, z;
   
int flag;
    scanf(
"%d",&T);
   
while(T--){
        scanf(
"%d%d",&n,&m);
        memset(degin,
0,sizeof(degin));
        memset(degout,
0,sizeof(degout));
        memset(map,
0,sizeof(map));
       
for(int i = 0; i < m; i++){
            scanf(
"%d%d%d",&x,&y,&z);
            degout[x]
++;
            degin[y]
++;
           
if(!z)map[x][y]++;
        }
        flag
= 0;
       
for(int i = 1; i <= n && !flag; i++){
           
if((degin[i]+degout[i])%2)flag=1;
           
if(degin[i] > degout[i])
                map[i][n
+1] = (degin[i]-degout[i])/2;
           
else 
                map[
0][i] = (degout[i]-degin[i])/2;
        }
       
if(flag)
            printf(
"impossible\n");
       
else{
           
if(max_flow(n+2,map,0,n+1,flow))
                printf(
"possible\n");
           
else 
                printf(
"impossible\n");
        }
    }
   
return 0;
}

posted on 2011-12-25 21:28 哲學與程序 閱讀(313) 評論(0)  編輯 收藏 引用

導航

公告

歡迎訪問 http://zhexue.sinaapp.com

常用鏈接

隨筆分類(37)

隨筆檔案(41)

Algorithm

最新隨筆

搜索

最新評論

獨立博客: 哲學與程序
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一区二区三区在线看| 国产精品视频久久| 中文亚洲视频在线| 99视频热这里只有精品免费| 亚洲美女视频在线观看| 亚洲日产国产精品| 久久这里只有精品视频首页| 久久综合影视| 亚洲国产一二三| 在线一区欧美| 久久精品亚洲| 欧美精品一区二区三| 国产精品免费网站在线观看| 国产一区二区精品久久91| 亚洲国产精品激情在线观看| 在线亚洲一区二区| 久久久av水蜜桃| 欧美激情第二页| 亚洲视频专区在线| 久久琪琪电影院| 欧美视频不卡| 黑丝一区二区三区| 一区二区三区欧美| 久久亚洲私人国产精品va| 亚洲国产精品一区制服丝袜| 亚洲在线观看视频网站| 欧美ed2k| 国产综合久久久久久鬼色| 欧美一区永久视频免费观看| 乱人伦精品视频在线观看| 国产精品久久久久天堂| 在线精品视频一区二区| 亚洲欧美日韩久久精品| 蜜臀a∨国产成人精品| 一区二区三区 在线观看视| 久久久久综合一区二区三区| 国产精品高潮呻吟久久av黑人| 久久夜色撩人精品| 久久在线视频在线| 亚洲高清在线精品| 久久gogo国模啪啪人体图| 美女啪啪无遮挡免费久久网站| 国产精品劲爆视频| 亚洲最快最全在线视频| 免费观看久久久4p| 午夜精品视频| 国产精品久久久久久久午夜片| 亚洲第一页中文字幕| 久久精品国产清高在天天线| 亚洲日本一区二区三区| 噜噜噜噜噜久久久久久91| 国产片一区二区| 亚洲一区观看| 亚洲精品免费在线| 浪潮色综合久久天堂| 韩国精品主播一区二区在线观看| 午夜精品久久久久久久99热浪潮| 日韩视频在线观看国产| 嫩草影视亚洲| 91久久精品www人人做人人爽 | 欧美a级大片| 国产一区二区三区高清在线观看| 亚洲免费视频中文字幕| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 国产精品进线69影院| 亚洲精品极品| 免费观看一区| 能在线观看的日韩av| 亚洲高清自拍| 欧美大片18| 欧美国产精品v| 亚洲精品系列| 一区二区高清| 国产欧美欧美| 欧美a级一区二区| 欧美国产第二页| 日韩亚洲欧美成人一区| 99ri日韩精品视频| 国产日韩亚洲欧美| 美脚丝袜一区二区三区在线观看| 久久一区二区视频| 亚洲精品自在在线观看| 日韩亚洲欧美精品| 国产日韩精品久久久| 午夜精品www| 国产视频一区在线观看一区免费| 久久综合999| 亚洲人成网站在线播| 欧美精品99| 9l国产精品久久久久麻豆| 一本色道久久综合亚洲91| 亚洲伊人网站| 久久一本综合频道| 日韩亚洲欧美中文三级| 美女精品在线| 一区二区成人精品| 一区二区欧美视频| 国产毛片精品国产一区二区三区| 欧美中文字幕在线播放| 久久久久久久尹人综合网亚洲| 亚洲高清视频一区二区| 99国产精品视频免费观看| 国产精品一区在线观看| 欧美国产91| 国产精品久久久99| 欧美1区2区| 国产精品久久二区二区| 美女精品国产| 国产精品嫩草99a| 欧美电影免费观看高清| 国产乱码精品一区二区三| 欧美大胆a视频| 国产亚洲激情在线| 国产精品亚洲视频| 在线看日韩av| 99精品欧美| 亚洲激情中文1区| 午夜精彩视频在线观看不卡| 日韩一区二区精品| 久久成人精品视频| 午夜免费久久久久| 欧美日韩大片| 欧美激情视频给我| 国模叶桐国产精品一区| 亚洲一区在线视频| 国产精品自拍网站| 99在线精品免费视频九九视| 在线精品视频一区二区| 亚洲少妇一区| 亚洲视频电影在线| 欧美激情在线免费观看| 欧美国产精品| 亚洲国产欧美在线| 老司机午夜精品| 免费观看成人www动漫视频| 国产欧美精品va在线观看| 亚洲作爱视频| 亚洲午夜精品在线| 欧美日韩国产一区精品一区| 欧美国产日韩一区二区三区| 亚洲电影免费观看高清完整版在线观看 | 狠狠色狠狠色综合日日小说| 性欧美video另类hd性玩具| 亚洲一区精品在线| 国产精品高潮呻吟久久av黑人| 欧美激情一区二区三区全黄 | 久热这里只精品99re8久| 日韩午夜电影| 欧美日韩在线视频观看| 欧美一区二区三区在线观看视频| 亚洲欧美电影院| 欧美日韩亚洲一区二区| 欧美电影免费观看高清| 亚洲激情在线播放| 欧美96在线丨欧| 91久久在线播放| 亚洲精品国产视频| 欧美日韩第一区| 亚洲性夜色噜噜噜7777| 久久国产精品99久久久久久老狼| 国产日韩成人精品| 麻豆免费精品视频| 亚洲精品一区二区三区婷婷月| 亚洲一二三区精品| 国产日韩欧美一区二区| 久久蜜桃资源一区二区老牛| 91久久精品国产91性色tv| 亚洲一区国产精品| 国产在线精品自拍| 欧美激情免费观看| 亚洲午夜91| 欧美成人黄色小视频| 在线一区二区视频| 国产综合婷婷| 欧美日韩精品福利| 久久精品电影| 一区二区欧美在线| 亚洲第一在线综合网站| 亚洲在线1234| 亚洲第一精品电影| 国产精品电影观看| 欧美.com| 欧美影院一区| 在线亚洲+欧美+日本专区| 另类综合日韩欧美亚洲| 亚洲少妇诱惑| 在线日韩中文| 国产欧美日韩视频一区二区三区| 牛牛国产精品| 欧美一二三视频| 亚洲免费观看高清在线观看 | 亚洲视频网站在线观看| 国产精品电影观看| 欧美成人免费在线观看| 久久成人资源| 亚洲欧美日韩国产综合在线| 亚洲狼人综合| 亚洲第一网站| 久久伊人一区二区| 欧美在线资源|