题意:

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

题解:

本来是道计算几何的大讨论,被我生生写成了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. spring接收文件资源

    提交请求的contentType为multipart/form-data 图片提交在form中的名称为file 后端接收示例 @RequestMapping("/picture") ...

  2. SQL的判断重复新增或者修改

    <insert id="insertTankStatisticData" parameterType="java.util.Map"> <se ...

  3. 【leetcode】955. Delete Columns to Make Sorted II

    题目如下: We are given an array A of N lowercase letter strings, all of the same length. Now, we may cho ...

  4. C/C++ fgets

    {     str_normalize_init();    unsigned options = SNO_TO_LOWER | SNO_TO_HALF;    if (argc > 1)    ...

  5. Yii2的一些问题

    Yii2中删除能不能串着用 Yii2中find.findAll有什么区别 Yii2中User::findOne($id)和User::find->where(['id'=>1])-> ...

  6. cdn 链接

    1.jquery    :   http://www.jq22.com/cdn/ 2.常用前端库引用地址  :  http://www.jq22.com/jquery/jquery.html 3.vC ...

  7. jmeter登录之-动态参数

    jmeter登录之-动态参数 1.抓包查看提交的登录参数 发现参数authenticity_token是动态的,每次都不一样,所以回放的时候就会失败 2.提取动态变化的参数-后置处理器(相当于LR的关 ...

  8. 机器学习技法笔记:Homework #7 Decision Tree&Random Forest相关习题

    原文地址:https://www.jianshu.com/p/7ff6fd6fc99f 问题描述 程序实现 13-15 # coding:utf-8 # decision_tree.py import ...

  9. 拾遗:vim 快捷键设置

    ~/.vimrc 零.批量注释与反注释 :sp / :vsp       横向 / 纵向拆分窗口 :e            打开新文件 zc:拆叠代码 / zo:展开代码 set foldmetho ...

  10. JPA安装配置

    现在让我们继续安装JPA,如下几个步骤. 第一步:确认已经Java安装 首先,需要在系统上安装Java软件开发工具包(SDK).为了验证这一点,根据所使用的平台执行以下两个命令. 如果Java安装已正 ...