题意:

给定两个矩形,输出这两个矩形把平面分成了多少块。

题解:

本来是道计算几何的大讨论,被我生生写成了bfs。

离散化边,注意不重合的边中间要空出来一格,四周也要空出来一圈,然后暴力bfs计算一共有几块即可。

不这么暴力的方法倒也不是没有,观察下图,点与长方形的关系存在如下25种,那么两点确定一个长方形,两个长方形的关系则共有625种

至于这个表怎么打,好像还得借助一下bfs。

#include<iostream>
#include<queue>
#include<algorithm>
#include<cstring>
using namespace std;
int mapp[][];
int x[],y[];
const int changex[]={,,,-};
const int changey[]={,-,,};
void lsh(int *a){
int b[];
bool flag[]={};
b[]=a[];b[]=a[];b[]=a[];b[]=a[];
sort(b+,b+);
int l=unique(b+,b+)-b-;
for(int i=;i<=l;i++){
for(int j=;j<=;j++){
if(a[j]==b[i] && flag[j]==){
a[j]=*i;
flag[j]=;
}
}
}
return ;
}
int solve(){
int ans=;
memset(mapp,,sizeof mapp);
// printf("a:%d %d %d %d\n",x[1],y[1],x[2],y[2]);
// printf("b:%d %d %d %d\n",x[3],y[3],x[4],y[4]);
for(int i=;i<=;i++){
for(int j=;j<=;j++){
if((i==x[] || i==x[]) && j>=y[] && j<=y[]){
mapp[i][j]=-;
}
if((j==y[] || j==y[]) && i>=x[] && i<=x[]){
mapp[i][j]=-;
}
if((i==x[] || i==x[]) && j>=y[] && j<=y[]){
mapp[i][j]=-;
}
if((j==y[] || j==y[]) && i>=x[] && i<=x[]){
mapp[i][j]=-;
}
}
} // for(int i=1;i<=10;i++){
// for(int j=1;j<=10;j++){
// printf("%c ",mapp[i][j]==-1?'*':mapp[i][j]+'0');
// }
// printf("\n");
// }
//
queue<int> qx,qy;
for(int i=;i<=;i++){
for(int j=;j<=;j++){
if(mapp[i][j]==){
ans++;
mapp[i][j]=ans;
qx.push(i);
qy.push(j);
}
while(!qx.empty()){
int xx=qx.front();
int yy=qy.front();
qx.pop();qy.pop();
// printf("%d %d:",xx,yy);
for(int k=;k<;k++){
int xxx=xx+changex[k];
int yyy=yy+changey[k];
// printf("%d %d ",xxx,yyy);
if(xxx>= && xxx<= && yyy>= && yyy<= && mapp[xxx][yyy]==){
qx.push(xxx);
qy.push(yyy);
mapp[xxx][yyy]=ans;
}
}
// printf("\n");
}
// for(int i=1;i<=10;i++){
// for(int j=1;j<=10;j++){
// printf("%c ",mapp[i][j]==-1?'*':mapp[i][j]+'0');
// }
// printf("\n");
// }
}
}
return ans;
}
int main(){ int t;
scanf("%d",&t);
while(t--){
scanf("%d %d %d %d",&x[],&y[],&x[],&y[]);
scanf("%d %d %d %d",&x[],&y[],&x[],&y[]);
lsh(x);lsh(y);
printf("%d\n",solve());
// for(int i=1;i<=10;i++){
// for(int j=1;j<=10;j++){
// printf("%c ",mapp[i][j]==-1?'*':mapp[i][j]+'0');
// }
// printf("\n");
// }
}
}

hdu多校第八场 1009 (hdu6665) Calabash and Landlord 计算几何/dfs的更多相关文章

  1. 2014 HDU多校弟八场H题 【找规律把】

    看了解题报告,发现看不懂 QAQ 比较简单的解释是这样的: 可以先暴力下达标,然后会发现当前数 和 上一个数 的差值是一个 固定值, 而且等于当前数与i(第i个数)的商, 于是没有规律的部分暴力解决, ...

  2. hdu多校第八场Parentheses Matrix

    #include<bits/stdc++.h> using namespace std; ][]; int main() { int t; scanf("%d",&am ...

  3. hdu多校第十场 1009 (hdu6699) Block Breaker bfs/模拟

    题意: 紧密排列的方块因为摩擦力一个一个稳定地挤在一起,但当一个方块的四个邻居中,上下两个至少空缺一个,左右两个至少空缺一个,则这个方块也将掉落. 每次锤掉一个方块,求多少个方块受牵连落下. 题解: ...

  4. hdu多校第八场 1011 (hdu6667) Roundgod and Milk Tea 二分图匹配

    题意: 有若干个班,每个班有些人要喝奶茶,也提供一些奶茶,一人喝一杯,但是自己班的人不能喝自己班的奶茶,求最多能有多少人喝上奶茶. 题解: 典型的二分图匹配问题,学生在左,奶茶在右,学生和非自己班的奶 ...

  5. hdu多校第八场 1010(hdu6666) Quailty and CCPC 排序/签到

    题意: CCPC前10%能得金牌,给定队伍解题数和罚时,问你有没有一个队伍如果向上取整就金了,四舍五入就银了. 题解: 排序后按题意求解即可. #include<iostream> #in ...

  6. hdu多校第八场 1003 (hdu6659) Acesrc and Good Numbers 数论/打表

    题意: 对于某数k,若数字d在1-k中出现次数恰好为k,则称k为好数. 给定d,x,求x以内,对于d而言最大的好数.k范围1e18. 题解: 打表二分即可. 但是,1e18的表是没法打出来的,只能在o ...

  7. 2018 HDU多校第四场赛后补题

    2018 HDU多校第四场赛后补题 自己学校出的毒瘤场..吃枣药丸 hdu中的题号是6332 - 6343. K. Expression in Memories 题意: 判断一个简化版的算术表达式是否 ...

  8. 2018 HDU多校第三场赛后补题

    2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...

  9. 2019牛客多校第八场 F题 Flowers 计算几何+线段树

    2019牛客多校第八场 F题 Flowers 先枚举出三角形内部的点D. 下面所说的旋转没有指明逆时针还是顺时针则是指逆时针旋转. 固定内部点的答案的获取 anti(A)anti(A)anti(A)或 ...

随机推荐

  1. 使用cordova,监听安卓机物理返回按键,实现退出程序的功能

    在使用html5开发app时,并不能像Android原生那样调取手机自身的方法.而cordova正好弥补了html5这一缺陷. 一,在cordova中文网http://cordova.axuer.co ...

  2. php随机生成数字加字母的字符串

    function getRandomString($len, $chars=null) { if (is_null($chars)) { $chars = "ABCDEFGHIJKLMNOP ...

  3. 后端获取前端的多个数据用getlist

    authors = request.POST.getlist("authors") print(authors)  得到一串作者的名字

  4. Read Uncommitted

    Read Uncommitted是隔离级别最低的一种事务级别.在这种隔离级别下,一个事务会读到另一个事务更新后但未提交的数据,如果另一个事务回滚,那么当前事务读到的数据就是脏数据,这就是脏读(Dirt ...

  5. PHP FILTER_SANITIZE_SPECIAL_CHARS 过滤器

    定义和用法 FILTER_SANITIZE_SPECIAL_CHARS 过滤器对特殊字符进行 HTML 转义. 该过滤器用于转义 "<>& 以及 ASCII 值在 32 ...

  6. luoguP1313 [NOIp2011]计算系数 [组合数学]

    题目描述 给定一个多项式(by+ax)^k,请求出多项式展开后x^n*y^m 项的系数. 输入输出格式 输入格式: 输入文件名为factor.in. 共一行,包含5 个整数,分别为 a ,b ,k , ...

  7. 【hihocoder 1554】最短的 Nore0061

    [链接]http://hihocoder.com/problemset/problem/1554 [题意] 中文题 [题解] DP; 设f[i][j][k]表示前i个字符,第一个串已经得到了前j个字符 ...

  8. Hbase集群类型|集群配置|服务器选型|磁盘容量规划

    HBase和Hadoop的集群类型 1.单机模式 主要用于开发工作,一台机器上运行所有的守护进程,或者一台机器运行多个虚拟机.一般用于评估和测试. 2.小型集群 20台机器以内的集群,不同的机器运行不 ...

  9. Linux中断机制

    1.中断概念 中断是指在CPU正常运行期间,由于内外部事件或由程序预先安排的事件引起的CPU暂时停止正在运行的程序,转而为该内部或外部事件或预先安排的事件服务的程序中去,服务完毕后再返回去继续运行被暂 ...

  10. Sql生成 Insert 语句

    declare @TableName sysname select @TableName = 'T_OOSOrder' declare @result varchar(max) = 'INSERT I ...