• <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>

            pku3905 2-SAT問題 &我對2-SAT問題的最新理解

            最近看了人工智能的確定性推理,對2-SAT有了更深的理解,感覺2-SAT構圖過程就是構建的一個推理圖,邏輯關系是a->b。根據這題實際來講講
            就用第一種情況來舉例吧
            A被選或者B被選或者兩者都發生都是可以被接受的。
            那么如果A沒有被選,我們能推出B被選了。同樣如果B沒有被選,我們能推出A被選了,其他我們不能推出任何結論。
            所以構造關系
            !B->A
            !A->B
            反應到圖上就是兩條邊。
            這樣構圖完成后找出圖里所有的強連通分量,如果A和!A在同一個強連通分量里,那么就沖突了。(我們能推理出A->!A)
            代碼: 1 Source Code
             2 
             3 Problem: 3905        User: yzhw
             4 Memory: 16168K        Time: 2297MS
             5 Language: GCC        Result: Accepted
             6 Source Code
             7 # include <stdio.h>
             8 # include <stdlib.h>
             9 # include <string.h>
            10 # define N 2000
            11 # define M 1000000*2
            12 # define min(a,b) ((a)<(b)?(a):(b))
            13 # define abs(a) ((a)>0?(a):-(a))
            14 int n,m;
            15 int p,nxt[M],g[N],v[M];
            16 int stack[N],sp,dfn,low[N];
            17 void insert(int a,int b)
            18 {
            19     v[p]=b;
            20     nxt[p]=g[a];
            21     g[a]=p++;
            22 }
            23 int dfs(int pos)
            24 {
            25     int minnum=dfn++;
            26     int p;
            27     stack[sp++]=pos;
            28     low[pos]=minnum;
            29     for(p=g[pos];p!=-1;p=nxt[p])
            30     {
            31       if(low[v[p]]==-1)
            32         if(!dfs(v[p])) return 0;
            33       minnum=min(minnum,low[v[p]]);
            34     }
            35     if(minnum<low[pos]) low[pos]=minnum;
            36     else
            37     {
            38         do
            39         {
            40             low[stack[sp-1]]=N;
            41             if(abs(stack[sp-1]-pos)==n) return 0;
            42             sp--;
            43         }while(stack[sp]!=pos);
            44     }
            45     return 1;
            46 }
            47 int main()
            48 {
            49     while(scanf("%d%d",&n,&m)!=EOF)
            50     {
            51         int i,flag=1;
            52         memset(g,-1,sizeof(g));
            53         p=0;
            54         for(i=0;i<m;i++)
            55         {
            56             char str1[32],str2[32];
            57             int num1,num2;
            58             scanf("%s%s",str1,str2);
            59             num1=atoi(str1+1)-1;
            60             num2=atoi(str2+1)-1;
            61             if(*str1=='+'&&*str2=='+')
            62             {
            63                 insert(num1+n,num2);
            64                 insert(num2+n,num1);
            65             }
            66             else if(*str1=='-'&&*str2=='-')
            67             {
            68                 insert(num1,num2+n);
            69                 insert(num2,num1+n);
            70             }
            71             else if(*str1=='+'&&*str2=='-')
            72             {
            73                 insert(num1+n,num2+n);
            74                 insert(num2,num1);
            75             }
            76             else
            77             {
            78                 insert(num1,num2);
            79                 insert(num2+n,num1+n);
            80             }
            81         }
            82         memset(low,-1,sizeof(low));
            83         dfn=sp=0;
            84         for(i=0;i<2*n&&flag;i++)
            85             if(low[i]==-1)
            86                 if(!dfs(i)) flag=0;
            87         printf("%d\n",flag);
            88     }
            89     return 0;
            90 }

            posted on 2012-02-17 02:38 yzhw 閱讀(324) 評論(0)  編輯 收藏 引用 所屬分類: graph

            <2012年2月>
            2930311234
            567891011
            12131415161718
            19202122232425
            26272829123
            45678910

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            欧美精品一本久久男人的天堂| 国产福利电影一区二区三区久久久久成人精品综合 | 久久综合久久综合久久| 91久久精品无码一区二区毛片| 久久久久久久综合日本| 2021国产精品午夜久久 | 丰满少妇人妻久久久久久| 久久亚洲国产精品一区二区| 国产叼嘿久久精品久久| 久久婷婷五月综合色奶水99啪| 国产V综合V亚洲欧美久久| 久久精品无码一区二区日韩AV | 久久香蕉综合色一综合色88| 亚洲国产成人久久一区WWW| 亚洲va久久久噜噜噜久久| 2021少妇久久久久久久久久| 色综合久久最新中文字幕| 亚洲国产精品一区二区三区久久 | 国产激情久久久久影院小草| 中文成人无码精品久久久不卡| 大伊人青草狠狠久久| 久久婷婷色综合一区二区| 精品久久久久久无码中文字幕| 精品国产乱码久久久久久呢| 91久久成人免费| 久久精品www人人爽人人| 精品久久久久久久久免费影院| 亚洲国产精品婷婷久久| 久久久精品国产sm调教网站| 欧美久久亚洲精品| 国产精品久久久久乳精品爆| 狠狠色丁香久久婷婷综合五月 | 97久久精品无码一区二区天美| 亚洲?V乱码久久精品蜜桃| 99久久无码一区人妻| 国内精品久久九九国产精品| 人妻久久久一区二区三区| 久久人人爽人人爽人人爽| 色偷偷88欧美精品久久久| 久久精品无码av| 香蕉久久AⅤ一区二区三区|