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

gzwzm06

  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
  1 隨筆 :: 52 文章 :: 17 評論 :: 0 Trackbacks
2-SAT 問題
關鍵:建圖(建議先看趙爽的論文)
#include <stdio.h>
#include 
<cstring>
#include 
<stack>
using namespace std ;

const int MAXN = 2005 ;

struct Node{
    
int ID; 
    Node 
*next;
}
mapa[MAXN] ;

Node gTemp[
110001] ;
int gPos = 0 ;


int N , M ;    //點數 邊數
int g_Pred[MAXN], g_Num[MAXN], SN, flag[MAXN] ;
bool visited[MAXN];
stack
<int> g_Stack ;

void Insert(int a, int b)

    Node 
*= &gTemp[gPos++];
    p
->ID = b;
    p
->next = mapa[a].next;
    mapa[a].next 
= p;
}


void Build( const int& a , const int& b, const int& c, const char* cmd )
{
    
if ( strcmp( cmd , "AND" ) == 0 )
    
{
        
if ( c == 1 )
        
{
            Insert( a 
+ N, a ) ;
            Insert( b 
+ N, b ) ;
        }

        
else {
            Insert( a, b 
+ N ) ;
            Insert( b, a 
+ N ) ;
        }

    }

    
else if ( strcmp( cmd , "OR" ) == 0 )
    
{
        
if ( c == 1 )
        
{
            Insert( a 
+ N , b ) ;
            Insert( b 
+ N , a ) ;
        }

        
else {
            Insert( a, a 
+ N ) ;
            Insert( b, b 
+ N ) ;
        }

    }

    
else if ( strcmp( cmd , "XOR" ) == 0 )
    
{
        
if ( c == 1 )
        
{
            Insert( a 
+ N , b ) ;
            Insert( b 
+ N , a ) ;
            Insert( b , a 
+ N ) ;
            Insert( a , b 
+ N ) ;
        }

        
else {
            Insert( a 
+ N , b + N ) ;
            Insert( b 
+ N , a + N ) ;
            Insert( a , b ) ;
            Insert( b , a ) ;
        }

    }

}


int MIN( const int& a, const int& b )
{
    
return ( a < b ? a : b ) ;
}


// Tarjan算法 求SCC
void StrongDFS( int v )
{
    g_Pred[v] 
= g_Num[v] = SN++ ;

    g_Stack.push( v ) ;

    Node 
*ptr = mapa[v].next ;

    visited[v] 
= true ;

    
while ( ptr ){
        
if ( g_Num[ptr->ID] == 0 )
        
{
            StrongDFS( ptr
->ID ) ;
            g_Pred[v] 
= MIN( g_Pred[v], g_Pred[ptr->ID] ) ;
        }

        
else if ( g_Num[ptr->ID] < g_Num[v] && !visited[ptr->ID] )
        
{
            g_Pred[v] 
= MIN( g_Pred[v], g_Num[ptr->ID] ) ;
        }


        ptr 
= ptr->next ;
    }

    
if ( g_Pred[v] == g_Num[v] )
    
{
        
int w = g_Stack.top() ;
        g_Stack.pop() ;
        
while ( w != v )
        
{
            flag[w] 
= SN ;
            w 
= g_Stack.top() ;
            g_Stack.pop() ;
        }

        flag[w] 
= SN ;
    }

}


void StronglyCon()
{
    
int i ;

    memset(g_Num, 
0sizeof(g_Num)) ;
    memset(visited, 
0sizeof(visited)) ;
    memset(flag, 
0sizeof(flag)) ;
    SN 
= 1 ;

    
for ( i = 0 ; i < N * 2 ; ++i )
    
{
        
if ( g_Num[i] == 0 )
            StrongDFS( i ) ;
    }

}




void Init()
{
    gPos 
= 0 ;

    
int i ;

    
for ( i = 0 ; i < MAXN ; ++i )
    
{
        mapa[i].next 
= NULL ;
    }

    
while ( !g_Stack.empty() )
    
{
        g_Stack.pop() ;
    }

}



int main()
{
    
int i , first , second , third ;
    
char cmd[8] ;

    
while ( scanf("%d %d"&N, &M) != EOF )
    
{
        
        Init() ;

        
for ( i = 0 ; i < M ; ++i )
        
{
            scanf(
"%d %d %d %s"&first, &second, &third, &cmd) ;
            Build( first, second, third, cmd ) ;
        }


        StronglyCon() ;

        
bool ans = true ;

        
for ( i = 0 ; i < N ; ++i )
        
{
            
if ( flag[i] == flag[i + N] )
            
{
                ans 
= false ;
                
break ;
            }

        }


        
if ( ans )
        
{
            printf(
"YES\n") ;
        }

        
else {
            printf(
"NO\n") ;
        }

    }

    
return 0 ;
}

posted on 2008-10-30 23:26 閱讀(383) 評論(0)  編輯 收藏 引用 所屬分類: 圖論
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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在线播放一区| 亚洲精品国精品久久99热| 亚洲韩日在线| 免费成人黄色| 夜夜嗨av色综合久久久综合网 | 久热精品视频在线| 久久综合久久88| 亚洲美女性视频| 这里只有精品电影| 国产在线国偷精品产拍免费yy| 老牛嫩草一区二区三区日本| 欧美波霸影院| 亚洲伊人网站| 香蕉久久夜色精品国产使用方法| 在线看片欧美| 亚洲激情不卡| 国产女人精品视频| 暖暖成人免费视频| 欧美日韩在线高清| 久久精品久久99精品久久| 久久免费视频网站| 中文在线资源观看网站视频免费不卡| 午夜日韩电影| 亚洲人成免费| 亚洲欧美第一页| 精品成人一区二区三区| 亚洲美女中出| 狠狠色伊人亚洲综合成人| 最新国产成人在线观看| 国产精品一区二区欧美| 欧美激情一区二区三区蜜桃视频 | 亚洲伦理在线| 国产日韩欧美日韩| 亚洲国产成人av在线| 国产精品视频在线观看| 欧美高清日韩| 国产精品美女一区二区| 欧美国产精品va在线观看| 国产精品每日更新在线播放网址| 免费成人在线视频网站| 欧美日韩高清在线观看| 久久人人97超碰国产公开结果| 欧美激情偷拍| 久久免费高清| 欧美日韩三区| 男女精品视频| 国产精品美女久久久浪潮软件| 欧美国产视频日韩| 国产欧美一区二区色老头| 亚洲国产日韩精品| 国产资源精品在线观看| 一区二区成人精品 | 欧美大片免费观看在线观看网站推荐| 午夜精品久久久久久久男人的天堂 | 欧美大片免费| 国产精品免费网站在线观看| 亚洲国产精品久久久久婷婷老年| 国产亚洲欧美日韩精品| 99精品国产在热久久下载| 亚洲国产导航| 欧美一二三区精品| 亚洲一区在线播放| 欧美成人日韩| 久久久亚洲综合| 国产精品日韩一区| 亚洲美女在线国产| 亚洲狼人精品一区二区三区| 久久精品亚洲一区二区| 欧美亚洲在线| 欧美日韩在线视频一区| 亚洲国产精品一区二区www| 黑人一区二区三区四区五区| 亚洲一级高清| 亚洲一区久久久| 欧美久久99| 亚洲电影欧美电影有声小说| 激情成人av在线| 欧美一区日本一区韩国一区| 午夜亚洲性色视频| 国产精品ⅴa在线观看h| 亚洲精品日韩久久| 亚洲精品偷拍| 欧美11—12娇小xxxx| 美玉足脚交一区二区三区图片| 国产一区二区三区成人欧美日韩在线观看| 亚洲天堂久久| 亚洲永久视频| 欧美人与禽性xxxxx杂性| 欧美国产一区二区三区激情无套| 精品1区2区3区4区| 久久精品国产精品亚洲精品| 久久久久91| 国产亚洲人成网站在线观看| 午夜精品剧场| 亚洲一区观看| 国产精品成人aaaaa网站| 日韩一级黄色片| 一本色道久久综合亚洲精品不| 欧美国产综合视频| 亚洲国产精品传媒在线观看 | 亚洲精品日韩在线观看| 亚洲人成在线免费观看| 免费美女久久99| 亚洲国产日韩欧美| 亚洲免费av观看| 欧美精品久久久久久久| 亚洲精品日韩一| 制服丝袜激情欧洲亚洲| 欧美午夜国产| 亚洲综合色视频| 亚洲欧美在线一区二区| 国产乱人伦精品一区二区| 亚洲欧美日韩在线高清直播| 久久国产精品99久久久久久老狼| 国产欧美在线观看一区| 欧美伊人精品成人久久综合97| 久久久欧美一区二区| 一区在线播放视频| 另类酷文…触手系列精品集v1小说| 欧美电影免费| 亚洲精品在线观看免费| 欧美日韩一区二区在线观看| 亚洲一区二区三区四区中文| 久久av资源网站| 黄色成人免费网站| 久色成人在线| 亚洲精品在线电影| 亚洲女性裸体视频| 国产亚洲午夜高清国产拍精品| 先锋a资源在线看亚洲| 久久蜜臀精品av| 亚洲激情视频网| 欧美日韩一区二区国产| 亚洲影院污污.| 久久美女性网| 亚洲精选久久| 欧美午夜在线观看| 欧美在线观看一区| 欧美a级片网| 中日韩在线视频| 国产视频一区二区三区在线观看| 久久成人免费视频| 亚洲国产精品一区二区第四页av | 午夜精品久久久久久久| 黄色成人av| 欧美极品欧美精品欧美视频| 亚洲一区二区三区午夜| 你懂的成人av| 亚洲午夜高清视频| 国内精品久久久久久影视8| 欧美福利视频在线观看| 国产精品99久久久久久久久| 久久久久久久一区| 日韩亚洲欧美综合| 国产午夜精品久久久久久久| 老鸭窝91久久精品色噜噜导演| 亚洲精品乱码久久久久久蜜桃91| 欧美亚洲视频在线观看| 亚洲国产人成综合网站| 国产精品久久久久久av福利软件| 久久久在线视频| 宅男精品视频| 欧美aa国产视频| 亚洲综合首页| 一区久久精品| 国产精品视频xxx| 免费一级欧美片在线观看| 一区二区三区免费网站| 麻豆av一区二区三区| 亚洲一区免费| 亚洲黄色影院| 国产欧美日韩三区| 欧美国产日本韩| 午夜宅男欧美| 99精品99| 欧美福利视频在线观看| 久久国产加勒比精品无码| 亚洲精品在线免费观看视频| 国产婷婷色一区二区三区| 欧美久久久久中文字幕| 久久久久se| 亚洲午夜电影| 亚洲国产一区二区在线| 久久久青草婷婷精品综合日韩| 一区二区三区高清视频在线观看| 国内自拍视频一区二区三区| 国产精品久久久久久亚洲调教| 欧美不卡激情三级在线观看| 欧美在线免费观看| 亚洲伊人观看| 亚洲精选一区| 亚洲电影第1页| 老**午夜毛片一区二区三区| 欧美在线不卡| 亚洲手机成人高清视频| 亚洲精品一区二区在线| 国内成人精品2018免费看|