hdu多校第八场 1009 (hdu6665) Calabash and Landlord 计算几何/dfs
题意:
给定两个矩形,输出这两个矩形把平面分成了多少块。
题解:
本来是道计算几何的大讨论,被我生生写成了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的更多相关文章
- 2014 HDU多校弟八场H题 【找规律把】
看了解题报告,发现看不懂 QAQ 比较简单的解释是这样的: 可以先暴力下达标,然后会发现当前数 和 上一个数 的差值是一个 固定值, 而且等于当前数与i(第i个数)的商, 于是没有规律的部分暴力解决, ...
- hdu多校第八场Parentheses Matrix
#include<bits/stdc++.h> using namespace std; ][]; int main() { int t; scanf("%d",&am ...
- hdu多校第十场 1009 (hdu6699) Block Breaker bfs/模拟
题意: 紧密排列的方块因为摩擦力一个一个稳定地挤在一起,但当一个方块的四个邻居中,上下两个至少空缺一个,左右两个至少空缺一个,则这个方块也将掉落. 每次锤掉一个方块,求多少个方块受牵连落下. 题解: ...
- hdu多校第八场 1011 (hdu6667) Roundgod and Milk Tea 二分图匹配
题意: 有若干个班,每个班有些人要喝奶茶,也提供一些奶茶,一人喝一杯,但是自己班的人不能喝自己班的奶茶,求最多能有多少人喝上奶茶. 题解: 典型的二分图匹配问题,学生在左,奶茶在右,学生和非自己班的奶 ...
- hdu多校第八场 1010(hdu6666) Quailty and CCPC 排序/签到
题意: CCPC前10%能得金牌,给定队伍解题数和罚时,问你有没有一个队伍如果向上取整就金了,四舍五入就银了. 题解: 排序后按题意求解即可. #include<iostream> #in ...
- hdu多校第八场 1003 (hdu6659) Acesrc and Good Numbers 数论/打表
题意: 对于某数k,若数字d在1-k中出现次数恰好为k,则称k为好数. 给定d,x,求x以内,对于d而言最大的好数.k范围1e18. 题解: 打表二分即可. 但是,1e18的表是没法打出来的,只能在o ...
- 2018 HDU多校第四场赛后补题
2018 HDU多校第四场赛后补题 自己学校出的毒瘤场..吃枣药丸 hdu中的题号是6332 - 6343. K. Expression in Memories 题意: 判断一个简化版的算术表达式是否 ...
- 2018 HDU多校第三场赛后补题
2018 HDU多校第三场赛后补题 从易到难来写吧,其中题意有些直接摘了Claris的,数据范围是就不标了. 如果需要可以去hdu题库里找.题号是6319 - 6331. L. Visual Cube ...
- 2019牛客多校第八场 F题 Flowers 计算几何+线段树
2019牛客多校第八场 F题 Flowers 先枚举出三角形内部的点D. 下面所说的旋转没有指明逆时针还是顺时针则是指逆时针旋转. 固定内部点的答案的获取 anti(A)anti(A)anti(A)或 ...
随机推荐
- 使用cordova,监听安卓机物理返回按键,实现退出程序的功能
在使用html5开发app时,并不能像Android原生那样调取手机自身的方法.而cordova正好弥补了html5这一缺陷. 一,在cordova中文网http://cordova.axuer.co ...
- php随机生成数字加字母的字符串
function getRandomString($len, $chars=null) { if (is_null($chars)) { $chars = "ABCDEFGHIJKLMNOP ...
- 后端获取前端的多个数据用getlist
authors = request.POST.getlist("authors") print(authors) 得到一串作者的名字
- Read Uncommitted
Read Uncommitted是隔离级别最低的一种事务级别.在这种隔离级别下,一个事务会读到另一个事务更新后但未提交的数据,如果另一个事务回滚,那么当前事务读到的数据就是脏数据,这就是脏读(Dirt ...
- PHP FILTER_SANITIZE_SPECIAL_CHARS 过滤器
定义和用法 FILTER_SANITIZE_SPECIAL_CHARS 过滤器对特殊字符进行 HTML 转义. 该过滤器用于转义 "<>& 以及 ASCII 值在 32 ...
- luoguP1313 [NOIp2011]计算系数 [组合数学]
题目描述 给定一个多项式(by+ax)^k,请求出多项式展开后x^n*y^m 项的系数. 输入输出格式 输入格式: 输入文件名为factor.in. 共一行,包含5 个整数,分别为 a ,b ,k , ...
- 【hihocoder 1554】最短的 Nore0061
[链接]http://hihocoder.com/problemset/problem/1554 [题意] 中文题 [题解] DP; 设f[i][j][k]表示前i个字符,第一个串已经得到了前j个字符 ...
- Hbase集群类型|集群配置|服务器选型|磁盘容量规划
HBase和Hadoop的集群类型 1.单机模式 主要用于开发工作,一台机器上运行所有的守护进程,或者一台机器运行多个虚拟机.一般用于评估和测试. 2.小型集群 20台机器以内的集群,不同的机器运行不 ...
- Linux中断机制
1.中断概念 中断是指在CPU正常运行期间,由于内外部事件或由程序预先安排的事件引起的CPU暂时停止正在运行的程序,转而为该内部或外部事件或预先安排的事件服务的程序中去,服务完毕后再返回去继续运行被暂 ...
- Sql生成 Insert 语句
declare @TableName sysname select @TableName = 'T_OOSOrder' declare @result varchar(max) = 'INSERT I ...