Prelude

真是一道好题,然而比赛的时候花了太多时间在B题上,没时间想这个了QAQ。

题目链接:萌萌哒传送门(。^▽^)


Solution

观察样例和样例解释,我们发现,假如有四个点,恰好占据在某一个矩形的四个顶点上,那么这个矩形的四条边,都是可以自由选择画或者不画的。

这时候,我们称这四个点每个点“控制”了四条直线中的一条,可以自由选择这条直线画或者不画。这里可以配合样例解释理解一下。

考虑建立常用的图论模型——行列模型,把每一行抽象成一个点,每一列抽象成一个点,假如在\((x,y)\)处有一个点,那么用一条边连接第\(x\)行和第\(y\)列所代表的点。

在这个图上,每条边可以选择“控制”她所连接的两个点中的一个。

再次观察样例,发现如果四个点恰好占据在一个矩形的四个顶点上,那么这个连通块内会有一个环。

紧接着我们发现,如果在建出来的图上,某个连通块内有一个环的话,那么这个连通块内的每一个点,都可以被一条边“控制”,并且这些边不会重复。

也就是说,这个连通块内的每一个点所代表的直线,都是可以自由选择画或者不画的,因此,假设这个连通块内的点数为\(n\),则这个连通块内的方案数为\(2^{n}\)。

假如某一个连通块内没有环,即形成了一棵树,那么容易发现,只有“所有直线都画”这一种情况没法办到,因此,方案数为\(2^{n}-1\)。

根据乘法原理,每个连通块之间互不干扰,所以把每个连通块的方案数乘起来就好了。


Code

#include <cstring>
#include <algorithm>
#include <cstdio>
#include <map>
#include <cctype>
#include <queue> using namespace std;
typedef long long ll;
const int MAXN = 200010;
const int MOD = 1e9+7; int read() {
int x = 0, ch;
while( isspace(ch = getchar()) );
do x = x * 10 + ch - '0';
while( isdigit(ch = getchar()) );
return x;
} int n;
map<int,int> idx, idy;
int nid; namespace G {
int head[MAXN], nxt[MAXN], to[MAXN], m;
void init() {
memset(head, -1, sizeof head);
}
void adde( int u, int v ) {
to[m] = v, nxt[m] = head[u], head[u] = m++;
to[m] = u, nxt[m] = head[v], head[v] = m++;
}
} int fpow( int a, int b ) {
int c = 1;
while(b) {
if( b & 1 ) c = int(1LL * c * a % MOD);
a = int(1LL * a * a % MOD);
b >>= 1;
}
return c;
} int vis[MAXN];
queue<int> q;
int solve( int s ) {
using namespace G;
int e = 0, o = 0; // 边数和点数
vis[s] = 1, q.push(s);
while( !q.empty() ) {
int u = q.front(); q.pop();
++o;
for( int i = head[u]; ~i; i = nxt[i], ++e )
if( !vis[to[i]] )
vis[to[i]] = 1, q.push(to[i]);
}
e >>= 1;
return e == o-1 ? (fpow(2, o) - 1 + MOD) % MOD : fpow(2, o);
} int main() {
n = read();
G::init();
for( int i = 0; i < n; ++i ) {
int x = read(), y = read();
if( !idx[x] ) idx[x] = ++nid;
if( !idy[y] ) idy[y] = ++nid;
G::adde(idx[x], idy[y]);
}
int ans = 1;
for( int i = 1; i <= nid; ++i )
if( !vis[i] )
ans = int(1LL * ans * solve(i) % MOD);
printf( "%d\n", ans );
return 0;
}

【题解】Points, Lines and Ready-made Titles Codeforces 871C 图论的更多相关文章

  1. codeforces 872E. Points, Lines and Ready-made Titles

    http://codeforces.com/contest/872/problem/E E. Points, Lines and Ready-made Titles time limit per te ...

  2. Codeforces Round #440 (Div. 1, based on Technocup 2018 Elimination Round 2) C - Points, Lines and Ready-made Titles

    C - Points, Lines and Ready-made Titles 把行列看成是图上的点, 一个点(x, y)就相当于x行 向 y列建立一条边, 我们能得出如果一个联通块是一棵树方案数是2 ...

  3. Codeforces 870E Points, Lines and Ready-made Titles:并查集【两个属性二选一】

    题目链接:http://codeforces.com/problemset/problem/870/E 题意: 给出平面坐标系上的n个点. 对于每个点,你可以画一条经过这个点的横线或竖线或什么都不画. ...

  4. Codeforces 870E Points, Lines and Ready-made Titles 计数

    题目链接 题意 给定二维坐标上的\(n\)个点,过每个点可以 画一条水平线 或 画一条竖直线 或 什么都不画,并且若干条重合的直线被看做同一条.问共可能得到多少幅不同的画面? 题解 官方题解 仆の瞎扯 ...

  5. Codeforces 871C 872E Points, Lines and Ready-made Titles

    题 OvO http://codeforces.com/contest/871/problem/C ( Codeforces Round #440 (Div. 1, based on Technocu ...

  6. R语言:多个因变量时,如何在plot函数中画多条曲线(plot,points,lines,legend函数)

    最近阅读一篇文献<Regional and individual variations in the function of the human eccrine sweat gland>, ...

  7. Leaflet入门:添加点线面并导入GeoJSON数据|Tutorial of Leaflet: Adding Points, Lines, Polygons and Import GeoJSON File

    Web GIS系列: 1.搭建简易Web GIS网站:使用GeoServer+PostgreSQL+PostGIS+OpenLayers3 2.使用GeoServer+QGIS发布WMTS服务 3.使 ...

  8. Ant Man CodeForces - 704B (图论,贪心)

    大意: 给N个点,起点S终点T,每个点有X,A,B,C,D,根据I和J的X坐标可得I到J的距离计算公式 |xi - xj| + ci + bj seconds if j< i |xi - xj| ...

  9. [题解] [NOIP2008] 双栈排序——关系的冲突至图论解法

    Problem 题目描述 Tom最近在研究一个有趣的排序问题.如图所示,通过2个栈S1和S2,Tom希望借助以下4种操作实现将输入序列升序排序. 操作a 如果输入序列不为空,将第一个元素压入栈S1 操 ...

随机推荐

  1. mongodb4简明笔记

    就一数据库,掌握基本用法,其他的现学现卖就行了. 所以要把握基本套路. 创建数据库=>使用数据库=>创建集合=>使用集合=>创建文档=>使用文档 1.数据库 mongod ...

  2. ASP.NET MVC5 学习系列之视图

    一.视图约定 当创建一个项目模版时,可以注意到,项目以一种非常具体的方式包含了一个结构化的Views目录.在每一个控制器的View文件夹中,每一个操作方法都有一个同名的视图文件与其对应.(约定大于配置 ...

  3. 作业三C++

    作业心得 1.本次作业开始使用C++编写了(面向过程的C++,2333) 2.粗略学习了一下文件输入输出,和项目的创建等(在大佬眼里最基本的操作QAQ,然而我还是有点晕晕的,平时都是ctrl+n新建源 ...

  4. 软工实践-Alpha 冲刺 (7/10)

    队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 已经解决登录注册等基本功能的界面. 完成非功能的主界面制作 ...

  5. Java微笔记(7)

    String 类常用方法 注意点: 字符串 str 中字符的索引从0开始,范围为 0 到 str.length()-1 使用 indexOf 进行字符或字符串查找时,如果匹配返回位置索引:如果没有匹配 ...

  6. IE报错:SCRIPT1010: 缺少标识符

    原文 http://keenwon.com/989.html 昨天用IE11测试页面的时候,发现在文档模式调整到IE8的时候,会报错: 看了半天,百思不得其解,后来终于顿悟:delete是javasc ...

  7. JS在当前页面插入<script>标签,并执行

    将<script>标签绑定到<html>上, html可换成body,header等其他存在的标签. var htmm =document.getElementsByTagNa ...

  8. C语言添加宏开关

    原文地址:http://blog.csdn.net/cp1300/article/details/7773239 我们在写程序的时候,总是或多或少会加入一些printf之类的语句用于输出调试信息,但是 ...

  9. javascript 排序

    // 插入排序 将第一待排序序列第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列. 从头到尾依次扫描未排序序列,将扫描到的每个元素插入有序序列的适当位置.(如果待插入的元素与有序 ...

  10. 使用ResourceBundle 类读取 src 下的 xxx.properties 文件

    之前要读取 src 下的 .properties 文件都是使用的类加载器,加载类路径下的资源文件当做一个流来处理,load 到一个 Properties 对象上. jdbc.properties 代码 ...