P5816 [CQOI2010]内部白点 题解
【题目链接】
【解析】
好题。
拿到题目首先先看一下它的无解情况是怎么判断的。
然后很明显这个是不存在无解情况的。
因为它的黑点开始都是给定了的,可以理解为一个边界。
而新的变化的黑点不会往外扩张,那么也就意味着边界不会扩大。
边界不会扩大,那么变色过程就会终止。
然后考虑按着题目里的意思来看,你就会发现一个白点变为黑点,始终实在两个横坐标相同的点之间的。
这可以抽象为一根竖线,然后这个时候你发现只要出现了一根水平的线就对答案有贡献了。
那么,你就可以使用一种扫描线的过程。
对于竖线就是扫到上端点就执行单点减的过程,扫到下断点就单点加。
对于横线就直接区间查找一波,等价于寻找与它有交点的竖线个数。
然后就没了,不过坐标可能为负,所以需要离散化。
#include<bits/stdc++.h>
#define int long long
using namespace std;
template<typename T> inline void read(T &x){T f=1;x=0;char ch=getchar();while(!isdigit(ch)){if(ch=='-') f=-1;ch=getchar();}while(isdigit(ch)){x=(x<<1)+(x<<3)+(ch^48);ch=getchar();}x*=f;}
const int N = 6e5;
int n,xx[N],yy[N],c[N],ans,m1,m2,num;
struct node{int x,y;}a[N];
struct line{int x,y,rx,type;}l[N];
int mp(line x,line y){
if(x.y==y.y) return x.type<y.type;
else return x.y<y.y;
}
int cmp(node x,node y){if(x.y!=y.y)return x.y<y.y; return x.x<y.x;}
int comp(node x,node y){if(x.x!=y.x) return x.x<y.x;return x.y<y.y;}
int lowbit(int x){return x&(-x);}
void change(int x,int val){
for(int i=x;i<=N;i+=lowbit(i)) c[i]+=val;
}
int ask(int x){
int ans=0;
for(int i=x;i;i-=lowbit(i)) ans+=c[i];
return ans;
}
void work(){
sort(a+1,a+n+1,cmp);
for(int i=1;i<n;i++){
if(a[i].y==a[i+1].y){
l[++num].x=a[i].x;l[num].y=a[i].y;
l[num].rx=a[i+1].x;l[num].type=0;
}
}
sort(a+1,a+n+1,comp);
for(int i=1;i<n;i++){
if(a[i].x==a[i+1].x){
l[++num].x=a[i].x;l[num].y=a[i].y;l[num].type=1;
l[++num].x=a[i].x;l[num].y=a[i+1].y;l[num].type=-1;
}
}
sort(l+1,l+num+1,mp);
}
signed main(){
read(n);
for(int i=1;i<=n;i++) read(a[i].x),read(a[i].y),xx[i]=a[i].x,yy[i]=a[i].y;
sort(xx+1,xx+n+1);sort(yy+1,yy+n+1);
m1=unique(xx+1,xx+n+1)-1-xx;
m2=unique(yy+1,yy+n+1)-1-yy;
for(int i=1;i<=n;i++){
int val=lower_bound(xx+1,xx+m1+1,a[i].x)-xx;a[i].x=val;
val=lower_bound(yy+1,yy+m2+1,a[i].y)-yy;a[i].y=val;
}
work();
ans=n;
for(int i=1;i<=num;i++){
if(!l[i].type){
ans+=ask(l[i].rx-1)-ask(l[i].x);
}
else{
change(l[i].x,l[i].type);
}
}
cout<<ans;
return 0;
}
P5816 [CQOI2010]内部白点 题解的更多相关文章
- Bzoj1818: [Cqoi2010]内部白点 && Tyvj P2637 内部白点 扫描线,树状数组,离散化
1818: [Cqoi2010]内部白点 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 704 Solved: 344[Submit][Status] ...
- 【BZOJ1818】[CQOI2010]内部白点(树状数组,扫描线)
[BZOJ1818][CQOI2010]内部白点(树状数组,扫描线) 题面 BZOJ 题解 不难发现\(-1\)就是在搞笑的. 那么对于每一行,我们显然可以处理出来最左和最右的点,那么等价于我们在横着 ...
- 【BZOJ1818】[Cqoi2010]内部白点 扫描线+树状数组
[BZOJ1818][Cqoi2010]内部白点 Description 无限大正方形网格里有n个黑色的顶点,所有其他顶点都是白色的(网格的顶点即坐标为整数的点,又称整点).每秒钟,所有内部白点同时变 ...
- BZOJ_1818_[Cqoi2010]内部白点 _扫描线+树状数组
BZOJ_1818_[Cqoi2010]内部白点 _扫描线+树状数组 Description 无限大正方形网格里有n个黑色的顶点,所有其他顶点都是白色的(网格的顶点即坐标为整数的点,又称整点).每秒钟 ...
- bzoj 1818 Cqoi2010 内部白点 扫描线
[Cqoi2010]内部白点 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1126 Solved: 530[Submit][Status][Disc ...
- 【BZOJ】1818: [Cqoi2010]内部白点(树状数组+离散+特殊的技巧)
http://www.lydsy.com/JudgeOnline/problem.php?id=1818 这一题一开始我就看错了,bzoj的那个绝对值109简直坑人,应该是10^9,我直接写了个暴力. ...
- [CQOI2010]内部白点
Description 无限大正方形网格里有n个黑色的顶点,所有其他顶点都是白色的(网格的顶点即坐标为整数的点,又称整点).每秒钟,所有内部白点同时变黑,直到不存在内部白点为止.你的任务是统计最后网格 ...
- 1818: [Cqoi2010]内部白点
Time Limit: 10 Sec Memory Limit: 64 MB Submit: 1394 Solved: 625 [Submit][Status][Discuss] Descriptio ...
- bzoj1818 [Cqoi2010]内部白点
Description 无限大正方形网格里有n个黑色的顶点,所有其他顶点都是白色的(网格的顶点即坐标为整数的点,又称整点).每秒钟,所有内部白点同时变黑,直到不存在内部白点为止.你的任务是统计最后网格 ...
随机推荐
- [leetcode] 875. 爱吃香蕉的珂珂(周赛)
875. 爱吃香蕉的珂珂 这题时间要求比较严格... 首先,将piles排序,然后二分查找. 总之,答案K肯定位于piles[?]piles[?+1]或者1piles[0]之间 所以我们先二分把?找到 ...
- Go语言协程并发---select多路复用应用
package main import ( "fmt" "time" ) /* ·循环从一写两读三条管道中随机选择一条能走的路 ·等所有路都走不通了就退出循环 ...
- Go语言网络通信---连续通信的UDP编程
Server: package main import ( "fmt" "net" ) func main() { //创建udp地址 udpAddr, _ : ...
- 201871030132-熊文婷 实验二 个人项目―《D{0-1}KP问题》项目报告
项目 内容 课程班级博客链接 https://edu.cnblogs.com/campus/xbsf/2018CST 这个作业要求链接 https://www.cnblogs.com/nwnu-dai ...
- TensorFlow Keras API用法
TensorFlow Keras API用法 Keras 是与 TensorFlow 一起使用的更高级别的作为后端的 API.添加层就像添加一行代码一样简单.在模型架构之后,使用一行代码,可以编译和拟 ...
- RGB-D对红外热像仪和毫米波雷达标定
RGB-D对红外热像仪和毫米波雷达标定 Extrinsic Calibration of Thermal IR Camera and mmWave Radar by Exploiting Depth ...
- 狂神说redis笔记(二)
四.三种特殊数据类型 Geospatial(地理位置) 使用经纬度定位地理坐标并用一个有序集合zset保存,所以zset命令也可以使用 geoadd key longitud(经度) latitude ...
- 菜鸟刷题路:剑指 Offer 06. 从尾到头打印链表
剑指 Offer 06. 从尾到头打印链表 class Solution { public int[] reversePrint(ListNode head) { Stack<Integer&g ...
- 谈谈stream的运行原理
害,别误会,我这里说的stream不是流式编程,不是大数据处理框架.我这里说的是stream指的是jdk中的一个开发工具包stream. 该工具包在jdk8中出现,可以说已经是冷饭了,为何还要你说?只 ...
- Zabbix 4.0 使用笔记
自定义监控项1.确认需监控内容 (例如:登陆用户数)2.确认监控方法(例如:脚本)3.编写脚本 vi /etc/zabbix/custom_shell/current_login_user.sh# w ...