YbtOJ#853-平面标记【整体二分,凸壳】
正题
题目链接:http://www.ybtoj.com.cn/contest/119/problem/3
题目大意
给出\(n\)个点\((x_i,y_i)\),\(m\)次给出\((k_i,a_i)\)表示标记所有满足
\]
的未标记点
求每个点的标记时间
\(1\leq n,m\leq 10^5,1<a_i<10\)
解题思路
全是乘法所以可以先左右取\(ln\)就是
\]
把\(x,y,k\)取\(ln\)然后就是一个顺眼的式子
\]
虽然原题说\((x_i,y_i)\)是点,但是我们可以换个思路,把\((x_i,y_i)\)看成边(\(f(z)=x_iz+y_i\)),\((a_i,k_i)\)看成是点,然后问在每条边下面的编号最小的点是哪个。
这个就很好解决了,考虑整体二分。每次要考虑对于一条边是否有在\([L,mid]\)编号的点在它下面。可以对于所有的\([L,mid]\)的点拿出来构成一个下凸壳,然后根据每条边的斜率二分出一个最下面的点,然后只拿这个点判断就好了。
这样就是\(O(n\log^2 n)\)的了,如果肯写归并排序和凸壳用单调队列维护是可以做到\(O(n\log n)\)的
code
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
const int N=1e5+10;
int n,m,f[N],s[N],p[N],p1[N],p2[N],top,pos[N];
double x[N],y[N],k[N],z[N];
double xj(double x1,double y1,double x2,double y2)
{return x1*y2-x2*y1;}
double xl(int a,int b,int c){
double y1=k[b]-k[a],x1=z[b]-a[z];
double y2=k[c]-k[a],x2=z[c]-z[a];
return xj(x1,y1,x2,y2);
}
bool cmp(int x,int y)
{return z[x]<z[y];}
void solve(int Ln,int Rn,int Lm,int Rm){
if(Ln>Rn)return;
if(Lm==Rm){
for(int i=Ln;i<=Rn;i++)
f[p[i]]=Lm;
return;
}
int mid=(Lm+Rm)>>1;top=0;
sort(pos+Lm,pos+1+mid,cmp);
for(int i=Lm;i<=mid;i++){
while(top>1&&xl(s[top-1],s[top],pos[i])<=0)top--;
s[++top]=pos[i];
}
sort(pos+Lm,pos+1+mid);
int cnt1=0,cnt2=0;
for(int i=Ln;i<=Rn;i++){
int l=1,r=top-1;
while(l<=r){
int m=(l+r)>>1;
if(xj(z[s[m+1]]-z[s[m]],k[s[m+1]]-k[s[m]],1,x[p[i]])>0)l=m+1;
else r=m-1;
}
if(x[p[i]]*z[s[l]]+y[p[i]]>k[s[l]])p1[++cnt1]=p[i];
else p2[++cnt2]=p[i];
}
for(int i=1;i<=cnt1;i++)p[i+Ln-1]=p1[i];
for(int i=1;i<=cnt2;i++)p[Ln+cnt1+i-1]=p2[i];
solve(Ln,Ln+cnt1-1,Lm,mid);
solve(Ln+cnt1,Rn,mid+1,Rm);
return;
}
int main()
{
freopen("analysis.in","r",stdin);
// freopen("analysis.out","w",stdout);
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
scanf("%lf%lf",&x[i],&y[i]);
x[i]=log(x[i]);y[i]=log(y[i]);
p[i]=i;
}
for(int i=1;i<=m;i++){
scanf("%lf%lf",&k[i],&z[i]);
k[i]=log(k[i]);pos[i]=i;
}
solve(1,n,1,m);
for(int i=1;i<=n;i++)
if(f[i]==m)puts("-1");
else printf("%d\n",f[i]);
return 0;
}
YbtOJ#853-平面标记【整体二分,凸壳】的更多相关文章
- [BZOJ2726][SDOI2012]任务安排(DP+凸壳二分)
2726: [SDOI2012]任务安排 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1580 Solved: 466[Submit][Statu ...
- 【BZOJ3110】K大数查询(权值线段树套线段树+标记永久化,整体二分)
题意:有N个位置,M个操作.操作有两种,每次操作 如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个位置到第b个位置,第C大的数是 ...
- bzoj2402 陶陶的难题II 分数规划+树剖+线段树维护凸壳+二分
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=2402 题解 看上去很像分数规划的模型.于是就二分吧.令 \[ \begin{align*}\f ...
- YbtOJ#482-爬上山顶【凸壳,链表】
正题 题目链接:https://www.ybtoj.com.cn/contest/116/problem/2 题目大意 \(n\)个点,\(x\)坐标递增,第\(i\)个点向第\(j\)个点连边. 开 ...
- [学习笔记] CDQ分治&整体二分
突然诈尸.png 这两个东西好像都是离线骗分大法... 不过其实这两个东西并不是一样的... 虽然代码长得比较像 CDQ分治 基本思想 其实CDQ分治的基本思想挺简单的... 大概思路就是长这样的: ...
- CQD(陈丹琦)分治 & 整体二分——专题小结
整体二分和CDQ分治 有一些问题很多时间都坑在斜率和凸壳上了么--感觉斜率和凸壳各种搞不懂-- 整体二分 整体二分的资料好像不是很多,我在网上找到了一篇不错的资料: 整体二分是个很神的东西 ...
- BZOJ 1901 & 整体二分
题意: 带修改的区间第K小. SOL: 看了很久很久很久很久的整体二分,网上的各种题解也不是很多,也一直很不了解所谓的"贡献","将询问一起递归"是什么意思.. ...
- bzoj 3165: [Heoi2013]Segment 动态凸壳
3165: [Heoi2013]Segment Time Limit: 40 Sec Memory Limit: 256 MBSubmit: 202 Solved: 89[Submit][Stat ...
- 【BZOJ 3110】 [Zjoi2013]K大数查询(整体二分)
[题目] Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c如果是2 a b c形式,表示询问从第a个位置到 ...
随机推荐
- 《深入浅出vue.js》阅读笔记之(object)变化侦测
1.什么是变化侦测? 通常,在运行时应用内部的状态会不断发生变化,此时需要不停地重新渲染页面,这时如何确定状态中发生了什么变化? 变化侦测就是用来解决这个问题的,它分为两种类型,一种是"推& ...
- 3、二进制安装K8s之部署kube-apiserver
二进制安装K8s之部署kube-apiserver 一.生成 kube-apiserver 证书 1.自签证书颁发机构(CA) cat > ca-config.json <<EOF ...
- windows上解决git每次重复输入账号密码
win7电脑: 1.在 C:\Users\Administrator 下 编辑 .gitconfig文件 2.在原有内容下添加一行(此行作用为自动保存,保存修改后再使用一次GIT,输入账号密码后下次即 ...
- 后端开发应该掌握的Redis基础
转自:https://juejin.im/post/5d078cd6f265da1b8466e62c 在上一篇文章中,我们简单地讲了一下Redis的应用场景.安装.如何连接等比较基础的知识,那么在这篇 ...
- Int 2e 与 Sysenter区别
参考:张银奎<软件调试>第八章 Int 2e: Windows将2e号向量专门用作系统调用,在启动早起初始化中断描述表时便注册好了适合的服务例程.因此当NtDll中的NtReadFile发 ...
- dubbo(一)
1. Introduction 参考链接:https://www.baeldung.com/dubbo Dubbo is an open-source RPC and microservice fra ...
- 关于Java集合框架的总结
Java集合框架(都实现了Cloneable和Serializable接口)支持以下两个类型的容器: 一种是为了存储一个元素集合,简称集合(collection). 另一种是为了存储键/值对,称为图( ...
- http请求包含哪几个部分(请求行、请求头、请求体)
http协议报文 1.请求报文(请求行/请求头/请求数据/空行) 请求行 求方法字段.URL字段和HTTP协议版本 例如:GET ...
- 由Eratosthenes筛法演变出的一种素数新筛法
这两天和walls老师交流讨论了一个中学竞赛题,我把原题稍作增强和变形,得到如下一个题: 从105到204这100个数中至少要选取多少个数才能保证选出的数中必有两个不是互素的? 我们知道最小的几个素数 ...
- centos7环境变量配置错误以至于命令不可使用
2021-07-16 问题: centos7在配置环境变量的时候少打了$,导致很多命令不能使用 解决方法: 在命令行输入: export PATH=/usr/local/sbin:/usr/local ...