BZOJ2303 APIO2011方格染色(并查集)

时间:2022-10-29 10:08:01

  比较难想到的是将题目中的要求看做异或。那么有ai,j^ai+1,j^ai,j+1^ai+1,j+1=1。瞎化一化可以大胆猜想得到a1,1^a1,j^ai,1^ai,j=(i-1)*(j-1)&1。也就是说,确定第一行和第一列的颜色,就可以确定整个矩阵。现在如果没有已填的格子的限制,答案就是2n+m-1

  然后考虑已填格子。假设固定了a1,1,那么其影响到的就是a1,j和ai,1。即要求两者相同或不同。于是可以把每个格子的染色情况拆成两个点,根据已填格子将其连边,同一连通块内的点只要选择一个就必须全部选择。那么方案数就是2连通块个数/2。注意特判第一行或第一列格子已填的情况。

  细节比较麻烦,写完也不知道自己在干啥。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
int read()
{
int x=,f=;char c=getchar();
while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x*f;
}
#define P 1000000000
#define N 100010
int n,m,k,fa[N<<],color[N<<];
struct data{int x,y,c;
}a[N];
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
int solve(int c)
{
memset(color,,sizeof(color));
for (int i=;i<=(n+m-<<);i++) fa[i]=i;
for (int i=;i<=k;i++)
if (a[i].x!=&&a[i].y!=)
if ((a[i].c==c)^(((a[i].x-)&)*(a[i].y-)&)) fa[find((a[i].x-<<)-)]=find((n+a[i].y-<<)-),fa[find(a[i].x-<<)]=find(n+a[i].y-<<);
else fa[find((a[i].x-<<)-)]=find(n+a[i].y-<<),fa[find(a[i].x-<<)]=find((n+a[i].y-<<)-);
int cnt=;
for (int i=;i<=n+m-;i++) if (find((i<<)-)==find(i<<)) return ;
for (int i=;i<=k;i++)
{
if (a[i].x==&&a[i].y==){if (a[i].c!=c) return ;}
else
{
if (a[i].y==)
{
if (color[find((a[i].x-<<)-a[i].c)]!=-) color[find((a[i].x-<<)-a[i].c)]=;else return ;
if (color[find((a[i].x-<<)-(a[i].c^))]!=) color[find((a[i].x-<<)-(a[i].c^))]=-;else return ;
}
if (a[i].x==)
{
if (color[find((n+a[i].y-<<)-a[i].c)]!=-) color[find((n+a[i].y-<<)-a[i].c)]=;else return ;
if (color[find((n+a[i].y-<<)-(a[i].c^))]!=) color[find((n+a[i].y-<<)-(a[i].c^))]=-;else return ;
}
}
}
for (int i=;i<=(n+m-<<);i++)
if (find(i)==i&&!color[i]) cnt++;
cnt>>=;
int ans=;while (cnt--) ans=(ans<<)%P;
return ans;
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("bzoj2303.in","r",stdin);
freopen("bzoj2303.out","w",stdout);
const char LL[]="%I64d\n";
#else
const char LL[]="%lld\n";
#endif
n=read(),m=read(),k=read();
for (int i=;i<=k;i++) a[i].x=read(),a[i].y=read(),a[i].c=read();
cout<<(solve()+solve())%P;
return ;
}

BZOJ2303 APIO2011方格染色(并查集)的更多相关文章

  1. BZOJ2303 &lbrack;Apio2011&rsqb;方格染色 并查集

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ2303 题意概括 现在有一个N*M矩阵,矩阵上只能填数字0或1 现在矩阵里已经有一些格子被填写了数字 ...

  2. BZOJ 2303&colon; &lbrack;Apio2011&rsqb;方格染色 &lbrack;并查集 数学!&rsqb;

    题意: $n*m:n,m \le 10^6$的网格,每个$2 \times 2$的方格必须有1个或3个涂成红色,其余涂成蓝色 有一些方格已经有颜色 求方案数 太神了!!!花我三节课 首先想了一下只有两 ...

  3. &lbrack;BZOJ2303&rsqb;&lbrack;Apio2011&rsqb;方格染色

    [BZOJ2303][Apio2011]方格染色 试题描述 Sam和他的妹妹Sara有一个包含n × m个方格的 表格.她们想要将其的每个方格都染成红色或蓝色. 出于个人喜好,他们想要表格中每个2 × ...

  4. BZOJ2303&colon; &lbrack;Apio2011&rsqb;方格染色 【并查集】

    Description Sam和他的妹妹Sara有一个包含n × m个方格的表格.她们想要将其的每个方格都染成红色或蓝色.出于个人喜好,他们想要表格中每个2 × 2的方形区域都包含奇数个(1 个或 3 ...

  5. BZOJ2303 APIO2011方格染色

    这题太神了 首先我们可以发现只有当i和j都是偶数时a[1][1]^a[1][j]^a[i][1]^a[i][j]=1才满足情况,其它时都为0 所以我们可以先把i和j都为偶数的地方^1变为0 下面才是最 ...

  6. BZOJ&lowbar;2303&lowbar;&lbrack;Apio2011&rsqb;方格染色 &lowbar;并查集

    BZOJ_2303_[Apio2011]方格染色 _并查集 Description Sam和他的妹妹Sara有一个包含n × m个方格的 表格.她们想要将其的每个方格都染成红色或蓝色. 出于个人喜好, ...

  7. bzoj 2303&colon; &lbrack;Apio2011&rsqb;方格染色【并查集】

    画图可知,每一行的状态转移到下一行只有两种:奇数列不变,偶数列^1:偶数列不变,奇数列^1 所以同一行相邻的变革染色格子要放到同一个并查集里,表示这个联通块里的列是联动的 最后统计下联通块数(不包括第 ...

  8. bzoj 2303&colon; &lbrack;Apio2011&rsqb;方格染色

    传送门 Description Sam和他的妹妹Sara有一个包含n × m个方格的表格.她们想要将其的每个方格都染成红色或蓝色.出于个人喜好,他们想要表格中每个2 × 2的方形区域都包含奇数个(1 ...

  9. 【题解】P3631 &lbrack;APIO2011&rsqb;方格染色

    很有意思的一道题,所以单独拿出来了. 完整分享看 这里 题目链接 luogu 题意 有一个包含 \(n \times m\) 个方格的表格.要将其中的每个方格都染成红色或蓝色.表格中每个 \(2 \t ...

随机推荐

  1. SOA服务设计与实现的几个语言无关的原则速记

    一.SOA定义 SOA即面向服务架构(Service-Oriented Architecture).在SOA中,一切皆服务.一个服务是通过消息交换来调用的程序,一个信息系统是共同完成一个特定任务的一组 ...

  2. 深入浅出设计模式——解释器模式(Interpreter Pattern)

    模式动机 如果在系统中某一特定类型的问题发生的频率很高,此时可以考虑将这些问题的实例表述为一个语言中的句子,因此可以构建一个解释器,该解释器通过解释这些句子来解决这些问题.解释器模式描述了如何构成一个 ...

  3. WCF Service部署在IIS上

    环境vs2010,WCF应用程序.如何将WCF部署在IIS上. 第一步:右键点击项目,选择生成部署包. 第二步:在你项目所在的文件目录下找到Package文件夹,这就是我们的部署包所在的地方.在这个p ...

  4. AVCaptureSession 照相时获取 AVCaptureVideoPreviewLayer尺寸

    http://*.com/questions/14153878/avcapturesession-preset-photo-and-avcapturevideopreviewl ...

  5. python3中的进程

    由于GIL的存在,python中的多线程并不是真正的多线程. 如果想要充分的使用多核CPU的资源,在python中大部分情况需要使用多进程. 在计算机中,进程与进程这之间在内存中是相互独立的,是两块完 ...

  6. seaborn库

      首先找到Anaconda Prompt命令行,下载seaborn库 ,命令  pip install seaborn 1.风格设置 import seaborn as sns import num ...

  7. Spring:MVC

    摘要 Spring MVC 是一个开源的.基于MVC架构的WEB应用框架.这里记录MVC模型的概念以及Spring MVC 的请求处理流程. 关键词:Spring MVC 一.什么是Spring MV ...

  8. centos7 中搭建gitlab

    1.在virtual box中新建一个虚拟机 2.gitlab ce(community版本)地址:https://about.gitlab.com/installation/#centos-7?ve ...

  9. 元组(Tuple)

    元组(Tuple) 笛卡尔积中每一个元素(d1,d2,…,dn)叫作一个n元组(n-tuple)或简称元组. 元组是关系数据库中的基本概念,关系是一张表,表中的每行(即数据库中的每条记录)就是一个元组 ...

  10. Linux可执行文件后缀问题

    一般来说,可执行文件没有扩展名. Linux不根据扩展名判断文件类型,而是根据文件的内容来判断.所以扩展名的作用是帮助人来识别文件,对于Linux系统本身来说没有什么用处. .sh结尾表示是shell ...