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)或 ...
随机推荐
- leetcood学习笔记-35-二分法
题目: 第一次提交; class Solution: def searchInsert(self, nums: List[int], target: int) -> int: for i in ...
- BZOJ 3328: PYXFIB 解题报告
BZOJ 3328: PYXFIB 题意 给定\(n,p,k(1\le n\le 10^{18},1\le k\le 20000,1\le p\le 10^9,p \ is \ prime,k|(p- ...
- AcWing 203. 同余方程 (线性同余方程)打卡
求关于x的同余方程 ax ≡ 1(mod b) 的最小正整数解. 输入格式输入只有一行,包含两个正整数a,b,用一个空格隔开. 输出格式输出只有一行,包含一个正整数x,表示最小正整数解. 输入数据保证 ...
- AcWing 157. 树形地铁系统 (hash判断树同构)打卡
一些主要城市拥有树形的地铁系统,即在任何一对车站之间,有且只有一种方式可以乘坐地铁. 此外,这些城市大多数都有一个中央车站. 想象一下,你是一名在拥有树形地铁系统的城市游玩的游客,你想探索该城市完整的 ...
- div + css 边框 虚线
div + css 边框 虚线 dotted:[点线|有点的|点线式边框|点虚线] .introduce { border:1px dotted gray; margin:8px 5px 8px 10 ...
- POJ 3304 Segments (判断直线与线段相交)
题目链接:POJ 3304 Problem Description Given n segments in the two dimensional space, write a program, wh ...
- web自动化selenium click()方法失效的解决办法
使用Python写web-ui自动化脚本时,如果浏览器窗口比较小或者电脑屏幕比较小时, 可能会遇到页面元素的点击click()方法失效的问题,报错如下: Element <span>... ...
- JUC源码分析-集合篇(八)DelayQueue
JUC源码分析-集合篇(八)DelayQueue DelayQueue 是一个支持延时获取元素的无界阻塞队列.队列使用 PriorityQueue 来实现. 队列中的元素必须实现 Delayed 接口 ...
- Java多线程sleep和wait的区别,总结得非常好。
我们都知道sleep是让线程休眠,到时间后会继续执行,wait是等待,需要唤醒再继续执行,那么这两种方法在多线程中的表现形态,它们各有什么区别呢? 可以总结为以下几点. 使用上 从使用角度看,slee ...
- Pandas之read_excel()和to_excel()函数解析
read_excel() 加载函数为read_excel(),其具体参数如下. read_excel(io, sheetname=0, header=0, skiprows=None, skip_fo ...