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

POI 2001 Peaceful Commission 2-SAT問題

The Public Peace Commission should be legislated in Parliament of The Democratic Republic of Byteland according to The Very Important Law. Unfortunately one of the obstacles is the fact that some deputies do not get on with some others.

The Commission has to fulfill the following conditions:

  • Each party has exactly one representative in the Commission,
  • If two deputies do not like each other, they cannot both belong to the Commission.

Each party has exactly two deputies in the Parliament. All of them are numbered from 1 to 2n. Deputies with numbers 2i-1 and 2i belong to the i-th party .

Task

Write a program, which:

  • reads from the text file SPO.IN the number of parties and the pairs of deputies that are not on friendly terms,
  • decides whether it is possible to establish the Commission, and if so, proposes the list of members,
  • writes the result in the text file SPO.OUT.

Input

In the first line of the text file SPO.IN there are two non-negative integers n and m. They denote respectively: the number of parties, 1 <= n <= 8000, and the number of pairs of deputies, who do not like each other, 0 <= m <=2 0000. In each of the following m lines there is written one pair of integers a and b, 1 <= a < b <= 2n, separated by a single space. It means that the deputies a and b do not like each other.

There are multiple test cases. Process to end of file.

Output

The text file SPO.OUT should contain one word NIE (means NO in Polish), if the setting up of the Commission is impossible. In case when setting up of the Commission is possible the file SPO.OUT should contain n integers from the interval from 1 to 2n, written in the ascending order, indicating numbers of deputies who can form the Commission. Each of these numbers should be written in a separate line. If the Commission can be formed in various ways, your program may write any of them.

Sample Input

3 2
1 3
2 4

Sample Output

1
4
5
   最近看了2篇關(guān)于2-SAT問題的IOI論文,對(duì)2-SAT問題的O(m)時(shí)間復(fù)雜度的解法也有了一定的了解,找了道POI 2001的題來(lái)做,在WA了無(wú)數(shù)次之后終于過(guò)了,跑了1.44s,效率還可以。
2篇論文分別是<<由對(duì)稱性解2-SAT問題>>和<<2-SAT解法淺析>>。
//2-SAT問題
//求出所有強(qiáng)連通分量,如果有矛盾點(diǎn)同處于一個(gè)連通分量則無(wú)解
//縮點(diǎn),將原圖反向建立DAG圖
//按拓?fù)渑判蛑乙粋€(gè)未著色點(diǎn)x,染成紅色
//將與x矛盾的頂點(diǎn)及其子孫染為藍(lán)色
//直到所有頂點(diǎn)均被染色,紅色即為2-SAT的一組解
#include <iostream>
#include 
<vector>
#include 
<queue>
using namespace std;

const int MAXN = 16010;//2*8000
char color[MAXN];//染色
bool visit[MAXN];
queue
<int> q1,q2;
vector
< vector<int> > adj; //原圖
vector< vector<int> > radj;//逆向圖
vector< vector<int> > dag; //縮點(diǎn)后的逆向DAG圖
int n,m,cnt,id[MAXN],order[MAXN],ind[MAXN];//強(qiáng)連通分量,訪問順序,入度

void dfs(int u){
    visit[u]
=true;
    
int i,len=adj[u].size();
    
for(i=0;i<len;i++)
        
if(!visit[adj[u][i]])
            dfs(adj[u][i]);
    order[cnt
++]=u;
}

void rdfs(int u){
    visit[u]
=true;
    id[u]
=cnt;
    
int i,len=radj[u].size();
    
for(i=0;i<len;i++)
        
if(!visit[radj[u][i]])
            rdfs(radj[u][i]);
}

void korasaju(){
    
int i;
    memset(visit,
false,sizeof(visit));
    
for(cnt=0,i=1;i<=2*n;i++)
        
if(!visit[i]) dfs(i);
    memset(id,
0,sizeof(id));
    memset(visit,
false,sizeof(visit));
    
for(cnt=0,i=2*n-1;i>=0;i--)
        
if(!visit[order[i]])
            cnt
++,rdfs(order[i]);
}

bool solvable(){
    
for(int i=1;i<=n;i++)
        
if(id[2*i-1]==id[2*i])
            
return false;
    
return true;
}

void topsort(){
    
int i,j,len,now,p,pid;    
    
while(!q1.empty()){
        now
=q1.front();
        q1.pop();
        
if(color[now]!=0continue ;
        color[now]
='R';
        ind[now]
=-1;
        
for(i=1;i<=2*n;i++){
            
if(id[i]==now){
                p
=(i%2)?i+1:i-1;
                pid
=id[p];                        
                q2.push(pid);
                
while(!q2.empty()){
                    pid
=q2.front();
                    q2.pop();
                    
if(color[pid]=='B'continue ;            
                    color[pid]
='B';
                    
int len=dag[pid].size();
                    
for(j=0;j<len;j++)
                        q2.push(dag[pid][j]);
                }

            }

        }

        len
=dag[now].size();
        
for(i=0;i<len;i++){
            ind[dag[now][i]]
--;
            
if(ind[dag[now][i]]==0) q1.push(dag[now][i]);        
        }

    }

}

int main(){
    
int i,j,x,y,xx,yy,len;
    
while(scanf("%d %d",&n,&m)!=EOF){
        adj.assign(
2*n+1,vector<int>());
        radj.assign(
2*n+1,vector<int>());
        
for(i=0;i<m;i++){
            scanf(
"%d %d",&x,&y);
            xx
=(x%2)?x+1:x-1;
            yy
=(y%2)?y+1:y-1;
            adj[x].push_back(yy);
            adj[y].push_back(xx);
            radj[yy].push_back(x);
            radj[xx].push_back(y);
        }

        korasaju();
        
if(!solvable()) puts("NIE");
        
else{
            dag.assign(cnt
+1,vector<int>());
            memset(ind,
0,sizeof(ind));
            memset(color,
0,sizeof(color));
            
for(i=1;i<=2*n;i++){
                len
=adj[i].size();
                
for(j=0;j<len;j++)
                    
if(id[i]!=id[adj[i][j]]){
                        dag[id[adj[i][j]]].push_back(id[i]);
                        ind[id[i]]
++;
                    }

            }

            
for(i=1;i<=cnt;i++)
                
if(ind[i]==0) q1.push(i);
            topsort();
            
for(i=1;i<=n;i++){
                
if(color[id[2*i-1]]=='R') printf("%d\n",2*i-1);
                
else printf("%d\n",2*i);
            }

        }

    }

    
return 0;
}

posted on 2009-06-07 18:59 極限定律 閱讀(1188) 評(píng)論(1)  編輯 收藏 引用 所屬分類: ACM/ICPC

評(píng)論

# re: POI 2001 Peaceful Commission 2-SAT問題 2014-05-05 12:35 zzhhbyt

您用的求scc的算法應(yīng)該是叫做kosaraju而不是korasaju吧?  回復(fù)  更多評(píng)論   

<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美chengren| 免费视频久久| 亚洲福利视频专区| 欧美一区二区三区在线观看视频| 9色精品在线| 亚洲午夜精品福利| 亚洲免费在线观看视频| 性欧美大战久久久久久久免费观看 | 亚洲一区二区在线看| 亚洲综合色网站| 久久精品国产99| 蜜桃av久久久亚洲精品| 亚洲二区在线观看| 一区二区三区国产在线观看| 午夜国产一区| 久久综合狠狠| 国产精品福利在线观看| 韩国一区电影| 中文国产亚洲喷潮| 欧美在线观看视频| 亚洲国产精品黑人久久久| 亚洲作爱视频| 久久久蜜臀国产一区二区| 欧美日韩美女一区二区| 国产亚洲一区在线播放| 亚洲美女视频在线观看| 欧美在线一二三四区| 欧美电影免费网站| 中文日韩在线| 欧美影院在线| 亚洲高清在线精品| 亚洲欧美成aⅴ人在线观看| 久久久久网站| 国产精品人人做人人爽人人添| 好看的日韩视频| 亚洲一区二区免费| 欧美大片va欧美在线播放| 午夜在线精品偷拍| 欧美视频二区| 亚洲日韩中文字幕在线播放| 久久高清免费观看| 一区二区三区毛片| 欧美精品日日鲁夜夜添| 伊人成人在线视频| 一区二区三区免费看| 久久精品青青大伊人av| 亚洲天堂av在线免费观看| 欧美精品1区| 原创国产精品91| 午夜在线成人av| 在线视频欧美一区| 欧美日韩精品| 亚洲第一网站| 久久久91精品国产一区二区三区 | 欧美成人综合网站| 久久精品一区二区三区不卡| 欧美亚洲成人免费| 日韩一区二区高清| 亚洲人成在线影院| 欧美日本在线一区| 亚洲伦理一区| 亚洲毛片在线观看.| 欧美日韩精品系列| 亚洲午夜久久久| 一本色道久久综合精品竹菊| 国产精品国产三级国产a| 亚洲免费一级电影| 亚洲字幕在线观看| 国产日韩成人精品| 久久精品一本久久99精品| 欧美在线视频免费播放| 伊人久久成人| 亚洲欧洲一区二区三区在线观看| 欧美freesex8一10精品| 99国产精品久久久久久久成人热| 亚洲国产人成综合网站| 欧美韩日亚洲| 午夜精品视频在线| 久久久久九九视频| 亚洲美女区一区| 亚洲一级在线观看| 好吊视频一区二区三区四区| 欧美韩日一区| 国产精品久久国产精品99gif| 久久精品二区三区| 久久综合电影一区| 在线视频免费在线观看一区二区| 亚洲午夜精品久久| 麻豆精品在线播放| 亚洲麻豆av| 国产精品99久久久久久久久| 欧美日韩一二三四五区| 久久久精品tv| 欧美激情视频一区二区三区不卡| 亚洲欧美日韩在线一区| 久久久青草婷婷精品综合日韩| 日韩网站在线观看| 9国产精品视频| 国产综合久久久久久鬼色| 亚洲欧洲另类国产综合| 国产精品久久久久久久久久免费看| 久久字幕精品一区| 国产精品国产三级国产| 欧美激情一区二区三区在线视频观看| 欧美日韩网址| 久久在线免费观看视频| 国产精品久久久久免费a∨| 欧美高清在线精品一区| 欧美一区二区三区久久精品茉莉花| 亚洲欧洲精品一区| 亚洲欧美日韩在线高清直播| 最新中文字幕亚洲| 欧美亚洲网站| 午夜国产不卡在线观看视频| 欧美成人免费在线视频| 久久青草福利网站| 蜜桃av综合| 亚洲欧美资源在线| 国产精品99久久久久久白浆小说| 久久精品91| 欧美一区视频| 国产精品久久久久高潮| 亚洲精品日韩在线| 亚洲国产片色| 久久香蕉国产线看观看av| 久久久久久亚洲精品不卡4k岛国| 欧美视频在线一区二区三区| 亚洲高清不卡一区| 日韩视频一区二区| 一色屋精品亚洲香蕉网站| 亚洲一区二区高清| 一区二区三区四区蜜桃| 欧美日韩免费一区二区三区| 亚洲国产午夜| 日韩亚洲视频在线| 欧美激情综合亚洲一二区| 亚洲福利国产精品| 最新日韩中文字幕| 欧美高清在线播放| 亚洲免费成人av| 亚洲一区在线看| 国产精品麻豆欧美日韩ww| 中文久久精品| 久久国产精品一区二区三区四区| 国产欧美日韩精品丝袜高跟鞋| 亚洲小少妇裸体bbw| 亚洲免费在线看| 国产午夜精品理论片a级大结局| 亚洲欧美日韩一区二区在线| 久久久国产成人精品| 在线精品国产欧美| 久久精品91久久香蕉加勒比| 欧美jizz19性欧美| 亚洲精品孕妇| 国产精品日韩欧美一区二区三区| 91久久一区二区| 亚洲图片自拍偷拍| 欧美午夜精品一区| 亚洲一区综合| 久久在线免费观看| 亚洲精品在线视频观看| 欧美日韩亚洲一区三区| 亚洲欧美综合网| 免费日韩av电影| 一区二区三区日韩精品视频| 欧美日韩亚洲一区在线观看| 欧美一区在线视频| 亚洲高清一区二| 亚洲欧美在线网| 亚洲高清自拍| 国产精品久久久久久久久久免费| 欧美一二三视频| 亚洲欧洲日本在线| 欧美在线地址| 夜夜精品视频一区二区| 国产一区二区中文字幕免费看| 欧美大片一区二区三区| 亚洲自拍偷拍一区| 欧美激情第六页| 亚洲欧洲av一区二区| 亚洲欧洲在线看| 国产伦精品一区二区三区照片91 | 日韩视频在线一区| 欧美在线不卡| 99re在线精品| 国产偷自视频区视频一区二区| 男女激情久久| 午夜日韩av| 日韩视频一区二区三区在线播放| 久久亚洲综合色一区二区三区| 亚洲私人影院在线观看| 在线看片成人| 国产欧美视频一区二区三区| 欧美精品在欧美一区二区少妇| 久久久国际精品| 亚洲一区综合| 在线亚洲欧美专区二区| 亚洲国产精品精华液网站| 美玉足脚交一区二区三区图片| 亚洲欧美视频在线|