首先旋转坐标系,将范围表示成矩形或者射线

如果范围是一条线,则将灯按y坐标排序,y坐标相同的按x坐标排序,

对于y相同的灯,f[i]=min(i,它前面灯发光时刻的第k[i]小值),

线段树维护,$O(n\log n)$

如果范围是一个矩形,则将灯按x坐标排序,x坐标相同的按y坐标排序,

从左往右、从下到上依次扫描,f[i]=min(i,它左下角灯发光时刻的第k[i]小值),

权值线段树套SBT维护,$O(n\log^2n)$

#include<cstdio>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N=200010,M=524289;
int n,x1,y1,x2,y2,sig=1,i,j,x,y,f[N],q[N],cnt,flag;
struct P{ll x,y;int id,k;}a[N];
inline void up(int&x,int y){if(x>y)x=y;}
inline void read(int&a){
char c;bool f=0;a=0;
while(!((((c=getchar())>='0')&&(c<='9'))||(c=='-')));
if(c!='-')a=c-'0';else f=1;
while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';
if(f)a=-a;
}
namespace Mistake{
int v[M];
inline bool cmp(P a,P b){return a.y==b.y?a.x<b.x:a.y<b.y;}
void clear(int x,int a,int b){
if(!v[x])return;
v[x]=0;
if(a==b)return;
int mid=(a+b)>>1;
clear(x<<1,a,mid),clear(x<<1|1,mid+1,b);
}
void add(int x,int a,int b,int c){
v[x]++;
if(a==b)return;
int mid=(a+b)>>1;
if(c<=mid)add(x<<1,a,mid,c);else add(x<<1|1,mid+1,b,c);
}
inline int kth(int k){
if(v[1]<k)return n;
int x=1,a=1,b=n,mid,t;
while(a<b){
mid=(a+b)>>1,t=v[x<<=1];
if(k<=t)b=mid;else k-=t,a=mid+1,x++;
}
return a;
}
void work(){
sort(a+1,a+n+1,cmp),a[0].y=a[1].y-1;
for(i=1;i<=n;i++){
if(a[i].y!=a[i-1].y)clear(1,1,n);
up(f[a[i].id],kth(a[i].k)),add(1,1,n,f[a[i].id]);
}
}
}
namespace Normal{
ll b[N];int X,Y,K,lim,t;
inline bool cmp(P a,P b){return a.x==b.x?a.y<b.y:a.x<b.x;}
inline int lower(ll x){
int l=1,r=n,t,mid;
while(l<=r)if(b[mid=(l+r)>>1]<=x)l=(t=mid)+1;else r=mid-1;
return t;
}
struct node{
int val,sum;node*l,*r;
node(){val=sum=0;l=r=NULL;}
inline void up(){sum=l->sum+r->sum+1;}
}*blank=new(node),*T[M],pool[4000000],*cur;
inline void Rotatel(node*&x){node*y=x->r;x->r=y->l;x->up();y->l=x;y->up();x=y;}
inline void Rotater(node*&x){node*y=x->l;x->l=y->r;x->up();y->r=x;y->up();x=y;}
void Maintain(node*&x,bool f){
if(x==blank)return;
if(!f){
if(x->l->l->sum>x->r->sum)Rotater(x);
else if(x->l->r->sum>x->r->sum)Rotatel(x->l),Rotater(x);
else return;
}else{
if(x->r->r->sum>x->l->sum)Rotatel(x);
else if(x->r->l->sum>x->l->sum)Rotater(x->r),Rotatel(x);
else return;
}
Maintain(x->l,0),Maintain(x->r,1),Maintain(x,0),Maintain(x,1);
}
void Ins(node*&x){
if(x==blank){x=cur++;x->val=Y;x->l=x->r=blank;x->sum=1;return;}
x->sum++;
if(Y<x->val)Ins(x->l);else Ins(x->r);
Maintain(x,Y>=x->val);
}
inline void Ask(node*x){
t=0;
while(x!=blank)if(X<x->val)x=x->l;else{t+=x->l->sum+1;if(t>=K)return;x=x->r;}
}
inline void add(){
int a=1,b=n,mid,f=1,x=1;
while(a<b){
if(f)Ins(T[x]);
mid=(a+b)>>1;x<<=1;
if(f=X<=mid)b=mid;else a=mid+1,x|=1;
}
Ins(T[x]);
}
inline int kth(){
if(Ask(T[1]),t<K)return n;
int x=1,a=1,b=n,mid;
while(a<b){
mid=(a+b)>>1;x<<=1;
if(lim<=mid)t=n;else Ask(T[x]);
if(K<=t)b=mid;else{K-=t,a=mid+1,x|=1;if(a>=Y)return n;}
}
return a;
}
void work(){
cur=pool;
blank->l=blank->r=blank;
for(i=1;i<M;i++)T[i]=blank;
sort(a+1,a+n+1,cmp);
for(i=1;i<=n;i++)b[i]=a[i].y;
sort(b+1,b+n+1);
for(i=1;i<=n;i++){
X=lower(a[i].y),Y=a[i].id,K=a[i].k;
if(lim<=1&&(Ask(T[1]),t)>=a[i].k)f[a[i].id]=1;else up(f[a[i].id],kth());
Y=X,X=f[a[i].id],add();
if(X>lim)lim=X;
}
}
}
int main(){
read(n),read(x1),read(y1),read(x2),read(y2);
if((ll)x1*y2==(ll)x2*y1)x2=-y1,y2=x1,flag=1;
if((ll)x1*y2<(ll)x2*y1)sig=-1;
for(i=1;i<=n;i++){
read(x),read(y);
a[i].x=((ll)y2*x-(ll)x2*y)*sig;
a[i].y=((ll)x1*y-(ll)y1*x)*sig;
a[i].id=f[i]=i;
}
for(i=1;i<=n;i++)read(a[i].k);
if(flag)Mistake::work();else Normal::work();
for(i=1;i<n;i++)printf("%d ",f[i]);printf("%d",f[n]);
return 0;
}

  

BZOJ3833 : [Poi2014]Solar lamps的更多相关文章

  1. bzoj 3834 [Poi2014]Solar Panels 数论分块

    3834: [Poi2014]Solar Panels Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 367  Solved: 285[Submit] ...

  2. 【BZOJ3834】[Poi2014]Solar Panels 分块好题

    [BZOJ3834][Poi2014]Solar Panels Description Having decided to invest in renewable energy, Byteasar s ...

  3. BZOJ3834[Poi2014]Solar Panels——分块

    题目描述 Having decided to invest in renewable energy, Byteasar started a solar panels factory. It appea ...

  4. 【bzoj3834】[Poi2014]Solar Panels 数论

    题目描述 Having decided to invest in renewable energy, Byteasar started a solar panels factory. It appea ...

  5. 【BZOJ】3834: [Poi2014]Solar Panels

    http://www.lydsy.com/JudgeOnline/problem.php?id=3834 题意:求$max\{(i,j)\}, smin<=i<=smax, wmin< ...

  6. BZOJ3834 : [Poi2014]Solar Panels

    问题相当于找到一个最大的k满足在$[x_1,x_2]$,$[y_1,y_2]$中都有k的倍数 等价于$\frac{x_2}{k}>\frac{x_1-1}{k}$且$\frac{y_2}{k}& ...

  7. BZOJ3834 [Poi2014]Solar Panels 【数论】

    题目链接 BZOJ3834 题解 容易想到对于\(gcd(x,y) = D\),\(d\)的倍数一定存在于两个区间中 换言之 \[\lfloor \frac{a - 1}{D} \rfloor < ...

  8. [POI2014]Solar Panels

    题目大意: $T(T\le1000)$组询问,每次给出$A,B,C,D(A,B,C,D\le10^9)$,求满足$A\le x\le B,C\le y\le D$的最大的$\gcd(x,y)$. 思路 ...

  9. POI2014题解

    POI2014题解 [BZOJ3521][Poi2014]Salad Bar 把p当作\(1\),把j当作\(-1\),然后做一遍前缀和. 一个合法区间\([l,r]\)要满足条件就需要满足所有前缀和 ...

随机推荐

  1. centos7下cups + samba共打印服务的教程

    centos7系统我们用到的不多但是这款系统比centos6功能要强大了不少,下文来介绍一篇centos7下cups + samba,共打印服务的例子,具体如下所示.   这个算是rhce课程的篇外篇 ...

  2. RemObjects SDK Source For Delphi XE7

    原文:http://blog.csdn.net/tht2009/article/details/39545545 1.目前官网最新版本是RemObjects SDK for Delphi and al ...

  3. BZOJ 1455

    STL的基本用法 (居然能空间卡过去= =!!!) #include <cstdio> #include <ext/pb_ds/priority_queue.hpp> #inc ...

  4. 发个题目坑 二模03day1

    1.数列(seq2.pas/c/cpp) 题目描述 一个数列定义如下:f(1) = 1,f(2) = 1,f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7.给定 A ...

  5. Java单链表、双端链表、有序链表实现

    单链表: insertFirst:在表头插入一个新的链接点,时间复杂度为O(1) deleteFirst:删除表头的链接点,时间复杂度为O(1) 有了这两个方法,就可以用单链表来实现一个栈了,见htt ...

  6. 《ASP.NET MVC4 WEB编程》学习笔记------.net mvc实现原理ActionResult/View

    ActionResult ActionResult是Action的返回结果.ActionResult 有多个派生类,每个子类功能均不同,并不是所有的子类都需要返回视图View,有些直接返回流,有些返回 ...

  7. iOS __block类型变量作用域

    看下图 在c语言中,2个独立的函数是不可能互相访问局部变量的,但是__block提供了这个功能,它不单单能读变量,还可以对变量进行写!上图说明,block获得了i最后的真实值5,没有只取得0,这都是& ...

  8. Spring MVC前台使用html页面作为视图,配置静态资源后Controller控制器不起作用的解决办法

    1.Spring MVC搭建项目的时候,想使用html页面作为前端的视图,你会发现html页面不能访问,原因是由于Spring拦截器将其拦截寻找控制器的缘故,解决办法就是配置静态资源: <mvc ...

  9. Redis笔记(三)Redis的数据类型

    前面说过,Redis的一大特性是支持丰富的数据类型, 这为更多的应用场景提供了可能. Redis有五种数据类型,包括string,list,set,sorted set和hash,注意,Redis的数 ...

  10. Mac下搭建go语言开发环境

    一.下载安装go 到墙内下载go的安装包: http://www.golangtc.com/download 点击安装包然后进行安装 二.配置 1.查看环境 go version 2.安装完sdk之后 ...