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] 46. 全排列(Java)
46. 全排列 这题我们可以借用31. 下一个排列写的nextPermutation函数来做,稍微改造一下即可 注意要先给nums排个序 class Solution { // 当没有下一个排列时re ...
- 工作流中的数据持久化详解!Activiti框架中JPA的使用分析
Activiti中JPA简介 可以使用JPA实体作为流程变量, 并进行操作: 基于流程变量更新已有的JPA实体,可以在用户任务的表单中填写或者由服务任务生成 重用已有的领域模型,不需要编写显示的服务获 ...
- 总结springboot开启mybatis驼峰命名自动映射的三种方式
方式一:通过springboot的配置文件application.yml mybatis: configuration: map-underscore-to-camel-case: true 此方式是 ...
- .NET平台系列24:从.NET Framework迁移到.NET Core/.NET5的技术指南
系列目录 [已更新最新开发文章,点击查看详细] 本文讲解了在将代码从 .NET Framework 移植到 .NET(旧称为 .NET Core)时应考虑的事项. 对于许多项目,从 .NET ...
- 手把手使用Python语音识别,进行语音转文字
0. 太长不看系列,直接使用 在1.2官网注册后拿到APISecret和APIKey,直接复制文章2.4demo代码,确定音频为wav格式,采样率为16K,在命令行执行 python single_s ...
- Django(68)drf分页器的使用
前言 当后台返回的数据过多时,我们就要配置分页器,比如一页最多只能展示10条等等,drf中默认配置了3个分页面 PageNumberPagination:基础分页器,性能略差 LimitOffsetP ...
- 【题解】10-19秀秀的森林(forest)
我恨秀秀倍增LCA+离线 (时光倒流) 题目 秀秀有一棵带n个顶点的树T,每个节点有一个点权ai-.有一天,她想拥有两棵树,于是她从T中删去了一条边.第二天,她认为三棵树或许会更好一些.因此,她又从她 ...
- NOIP模拟测试5「星际旅行·砍树·超级树」
星际旅行 0分 瞬间爆炸. 考试的时候觉得这个题怎么这么难, 打个dp,可以被儿子贡献,可以被父亲贡献,还有自环,叶子节点连边可以贡献,非叶子也可以贡献,自环可以跑一回,自环可以跑两回, 关键是同一子 ...
- EEPROM工作原理透彻详解
原文链接点击这里 EEPROM(Electrically Erasable Programmable read only memory)即电可擦可编程只读存储器,是一种掉电后数据不丢失(不挥发)存储芯 ...
- MindSpore模型精度调优实战:如何更快定位精度问题
摘要:为大家梳理了针对常见精度问题的调试调优指南,将以"MindSpore模型精度调优实战"系列文章的形式分享出来,帮助大家轻松定位精度问题,快速优化模型精度. 本文分享自华为云社 ...