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

[轉]zoj 3646 并查集

Posted on 2012-10-15 21:04 lenohoo 閱讀(383) 評論(0)  編輯 收藏 引用
轉自小yai
把b[][]數組上的每個位拆開成兩個點i和i',(不超過32位),另外新加兩個點0和1,如果確定某點i對應的是0,則i與0點合并,i'點與1點合并;如果確定某點i對應的是1,則i與1合并,i'與0合并;如果確定兩點i和j對應的位是相反的數,則i與j'合并,j與i'合并;如果確定兩點對應的位是相同的數,則i與j合并,i'與j'合并。
最近比較忙,所以題解比較水,所以具體還是看代碼吧。
因為要空出數給0點和1點,所以我從1到n而不是從0到n-1,所以奇偶性的判斷要換一下。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 100000;
int p[maxn];
int b[505][505];
int n;
void init() {
    for(int i=0;i<(2*n+1)*32+100;i++) p[i] = i;   
}
int find(int x) {
    return x==p[x] ? x : p[x] = find(p[x]);   
}
void Union(int x,int y) {
    int a = find(x) , b = find(y);
    p[a] = p[b] = p[x] = p[y] = min(a , b);   
}
bool check() {
    for(int i=1;i<=n;i++) {
        for(int j=i+1;j<=n;j++)
            if(b[i][j] != b[j][i]) return 0;
        if(b[i][i] != 0) return 0;   
    }
    init();
    int m = 32 * n;
    for(int i=1;i<=n;i++)
        for(int j=i+1;j<=n;j++) {
            if(i % 2 == 0 && j % 2 == 0) {
                for(int k=0;k<32;k++) {
                    if(b[i][j] & (1<<k) == 0) {
                        int u = i*32+k , v = j*32+k;
                        if(find(u) == find(1) || find(v) == find(1) || find(u) == find(v+m)) return 0;
                        Union(u,0);
                        Union(v,0);
                        Union(u+m,1);
                        Union(v+m,1);
                    }   
                }   
            }   
            else if(i % 2 == 1 && j % 2 == 1) {
                for(int k=0;k<32;k++) {
                    if(b[i][j] & (1<<k)) {
                        int u = i* 32 + k , v = j*32+k;
                        if(find(u) == find(0) || find(v)==find(0) || find(u) == find(v+m)) return 0;
                        Union(u,1);
                        Union(v,1);
                        Union(u+m,0);
                        Union(v+m,0);   
                    }   
                }   
            }
            else {
                for(int k=0;k<32;k++) {
                    int u = i * 32 + k , v = j * 32 + k;
                    if(b[i][j] & (1<<k)) {
                        if(find(u) == find(v)) return 0;
                        Union(u,v+m);
                        Union(u+m,v);   
                    }
                    else {
                        if(find(u) == find(v+m)) return 0;
                        Union(u,v);
                        Union(u+m,v+m);   
                    }
                }   
            }
        }
    return 1;
}
int main() {
    while(~scanf("%d",&n)) {
        for(int i=1;i<=n;i++)
            for(int j=1;j<=n;j++)
                scanf("%d",&b[i][j]);
        if(check()) puts("YES");
        else puts("NO");   
    }
    return 0;   
}

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


posts - 3, comments - 1, trackbacks - 0, articles - 16

Copyright © lenohoo

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            免费成人黄色| 亚洲在线一区| 欧美精品18| 欧美电影在线观看| 激情五月综合色婷婷一区二区| 免费久久精品视频| 欧美高清成人| 亚洲国产精品黑人久久久| 久色婷婷小香蕉久久| 欧美福利精品| 日韩亚洲欧美高清| 亚洲欧美激情四射在线日| 性欧美暴力猛交69hd| 久久久美女艺术照精彩视频福利播放| 久久午夜视频| 欧美精品成人91久久久久久久| 欧美日韩在线播放三区四区| 国产精品你懂的在线欣赏| 国产欧美日本| 亚洲欧洲一二三| 亚洲男人第一网站| 六十路精品视频| 99国产精品国产精品久久| 亚洲欧美视频在线观看视频| 欧美在线一级视频| 欧美猛交免费看| 国模 一区 二区 三区| 亚洲美女黄网| 久久久青草婷婷精品综合日韩| 亚洲风情在线资源站| 亚洲欧美春色| 欧美啪啪成人vr| 亚洲欧美日本精品| 国产日韩专区在线| 亚洲视屏在线播放| 亚洲成人在线网| 午夜精品久久久久久久| 欧美福利在线| 国产一区二区三区免费不卡| 9i看片成人免费高清| 欧美一区二区三区在线免费观看| 亚洲手机在线| 欧美成人亚洲| 久久成人18免费网站| 欧美日韩亚洲一区二区| 亚洲成色最大综合在线| 久久精品国产亚洲a| 99这里只有精品| 欧美精品福利视频| 亚洲精品国久久99热| 免费视频一区| 久久精品一区二区| 国产午夜亚洲精品不卡| 午夜在线电影亚洲一区| 在线一区亚洲| 欧美日韩国产一级片| 日韩午夜精品视频| 亚洲人成绝费网站色www| 欧美 日韩 国产 一区| 亚洲高清不卡一区| 欧美福利视频一区| 一区二区三区回区在观看免费视频| 免费一级欧美在线大片| 1024国产精品| 亚洲成在人线av| 欧美成人精品在线| 亚洲美女在线一区| 日韩午夜在线观看视频| 欧美日韩亚洲成人| 亚洲综合三区| 欧美亚洲一区二区三区| 一区二区三区我不卡| 欧美成人蜜桃| 欧美日韩成人激情| 亚洲欧美日韩电影| 欧美一区二区精美| 一区二区三区亚洲| 欧美成人一区二免费视频软件| 蜜乳av另类精品一区二区| 亚洲精品乱码久久久久久黑人| 亚洲日本中文字幕区| 欧美日韩一区二区三区免费| 香蕉久久精品日日躁夜夜躁| 欧美在线播放高清精品| 国语自产偷拍精品视频偷| 嫩草成人www欧美| 欧美极品一区| 久久成人精品无人区| 六十路精品视频| 亚洲影视综合| 久久久欧美一区二区| 一区二区三区福利| 欧美一区二区在线免费播放| 欧美国产第一页| 91久久国产精品91久久性色| 欧美视频网址| 免费欧美在线| 国产精品无码专区在线观看| 美女啪啪无遮挡免费久久网站| 欧美日韩成人免费| 久久福利精品| 欧美午夜精彩| 亚洲丝袜av一区| 国产色婷婷国产综合在线理论片a| 另类尿喷潮videofree| 欧美日韩在线精品一区二区三区| 久久狠狠婷婷| 欧美日韩国产综合视频在线| 久久婷婷国产综合精品青草| 欧美日韩一区二区三区高清| 欧美大成色www永久网站婷| 国产精品毛片在线| 亚洲精品男同| 亚洲高清久久网| 欧美一区二区三区免费观看| 亚洲桃花岛网站| 欧美成熟视频| 欧美成人dvd在线视频| 国产精品日韩在线一区| 亚洲人成在线免费观看| 黄色亚洲大片免费在线观看| 亚洲一区二区三区三| 亚洲作爱视频| 欧美成人资源| 欧美成人免费网站| 国内精品久久久久影院 日本资源| 欧美精品一区在线| 欧美精品粉嫩高潮一区二区 | 午夜一区在线| 欧美日本二区| 亚洲欧洲精品一区二区| 销魂美女一区二区三区视频在线| 中日韩视频在线观看| 欧美精品亚洲| 亚洲精品视频一区| 中文日韩欧美| 欧美视频三区在线播放| 亚洲七七久久综合桃花剧情介绍| 亚洲激情国产| 欧美高清在线视频| 亚洲国产精品一区二区第一页| 亚洲国产精品va在线观看黑人| 欧美一区三区二区在线观看| 久久久精品国产免费观看同学 | 欧美成人性生活| 亚洲高清资源综合久久精品| 久久乐国产精品| 亚洲高清久久久| 一区二区三区视频免费在线观看| 欧美日韩国产一中文字不卡| 在线亚洲欧美视频| 久久精品国产成人| 亚洲第一页在线| 欧美日韩1234| 一区二区三区免费看| 久久国产精品久久精品国产| 亚洲大片精品永久免费| 性欧美大战久久久久久久久| 久久另类ts人妖一区二区| 亚洲黄色免费电影| 欧美视频二区| 久久精精品视频| 亚洲欧洲在线免费| 国产精品久久久久一区| 美女日韩在线中文字幕| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美人在线视频| 欧美怡红院视频一区二区三区| 久久久久网站| 一本色道久久综合狠狠躁篇怎么玩| 国产精品老牛| 男人天堂欧美日韩| 亚洲欧美电影院| 欧美激情一区二区在线 | 狂野欧美一区| 国产精品毛片| 91久久亚洲| 久久国产欧美精品| 国产一区免费视频| 乱中年女人伦av一区二区| 老司机免费视频久久| 亚洲精品少妇| 久久av红桃一区二区小说| 狠狠入ady亚洲精品经典电影| 久久久精品国产99久久精品芒果| 巨乳诱惑日韩免费av| 国产精品久久久久久久久久久久| 国产一区二区三区无遮挡| 性欧美8khd高清极品| 欧美成人午夜影院| 午夜在线不卡| 亚洲精品一线二线三线无人区| 欧美freesex交免费视频| 影音先锋在线一区| 妖精视频成人观看www| 亚洲黄色在线观看| 国产在线高清精品| 国产精品v欧美精品v日韩| 亚洲电影免费在线| 精品动漫av|