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

            <2011年1月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            一级做a爰片久久毛片看看| AV狠狠色丁香婷婷综合久久 | 国内精品久久久久久久久 | 日本精品一区二区久久久| 久久成人精品| 精品综合久久久久久98| 精品久久久久久久| 久久精品极品盛宴观看| 久久午夜伦鲁片免费无码| 精品久久久久久综合日本| 国产精品久久久久久久app| 国产成人综合久久综合| 久久婷婷人人澡人人爽人人爱| 99精品国产在热久久无毒不卡| 亚洲欧美日韩精品久久亚洲区 | 久久久综合香蕉尹人综合网| 色婷婷久久综合中文久久蜜桃av| 91精品婷婷国产综合久久| 无码伊人66久久大杳蕉网站谷歌 | 日韩美女18网站久久精品| 久久超碰97人人做人人爱| 一本一道久久a久久精品综合| 国产精品一区二区久久不卡| 久久国产色av免费看| 久久久WWW成人免费毛片| 一本色道久久88加勒比—综合| 奇米影视7777久久精品人人爽| 久久久精品国产亚洲成人满18免费网站 | 久久亚洲国产成人影院| 色噜噜狠狠先锋影音久久| 蜜臀久久99精品久久久久久小说| 久久精品视频一| 色偷偷88欧美精品久久久| 国产巨作麻豆欧美亚洲综合久久| 日本久久久久久中文字幕| 国内精品久久久久久99蜜桃 | 色综合久久久久久久久五月| 久久久久久精品免费免费自慰| 久久综合久久伊人| 久久人与动人物a级毛片| 久久婷婷人人澡人人爽人人爱|