• 题解:

    • 求出$A$ 和$-B$ 的$Minkowsiki$和再$O(logn)$判断一个点是否在凸包内;
    • $Minkowsiki$的求法比较容易忘,要多多温习才可以;
  •  #include<bits/stdc++.h>
    #define ld long long
    using namespace std;
    const int N=;
    int n,m,q;
    struct P{
    ld x,y;
    P(ld _x=,ld _y=):x(_x),y(_y){};
    bool operator <(const P&a)const{return x==a.x?y<a.y:x<a.x;}
    P operator -(const P&a)const{return P(x-a.x,y-a.y);}
    P operator +(const P&a)const{return P(x+a.x,y+a.y);}
    }p1[N],p2[N],ch[N],p[N<<],Q;
    ld crs(P a,P b){return a.x*b.y-a.y*b.x;}
    ld len(P a){return a.x*a.x+a.y*a.y;}
    bool cmpQ(P a,P b){return crs(a,b)>||(crs(a,b)==&&len(a)<len(b));}
    char gc(){
    static char*P1,*P2,s[];
    if(P1==P2)P2=(P1=s)+fread(s,,,stdin);
    return(P1==P2)?EOF:*P1++;
    }
    int rd(){
    int x=,f=;char c=gc();
    while(c<''||c>''){if(c=='-')f=-;c=gc();}
    while(c>=''&&c<=''){x=x*+c-'';c=gc();}
    return x*f;
    }
    void convex(P *p,int&cnt){
    sort(p+,p+cnt+);
    int top,tmp;
    ch[top=]=p[];
    for(int i=;i<=cnt;++i){
    while(top>&&crs(ch[top]-ch[top-],p[i]-ch[top])<=)top--;
    ch[++top]=p[i];
    }
    tmp=top;
    for(int i=cnt-;i;--i){
    while(top>tmp&&crs(ch[top]-ch[top-],p[i]-ch[top])<=)top--;
    ch[++top]=p[i];
    }
    for(int i=;i<=top;++i)p[i]=ch[i];
    cnt=--top;
    }
    bool check(P Q){
    if(crs(p[],Q)<||crs(p[n],Q)>)return false;
    int pos=lower_bound(p+,p+n+,Q,cmpQ)-p-;
    return crs(p[pos+]-p[pos],Q-p[pos])>=;
    }
    int main(){
    #ifndef ONLINE_JUDGE
    freopen("war.in","r",stdin);
    freopen("war.out","w",stdout);
    #endif
    n=rd();m=rd();q=rd();
    for(int i=;i<=n;++i)p1[i].x=rd(),p1[i].y=rd();
    for(int i=;i<=m;++i)p2[i].x=-rd(),p2[i].y=-rd();
    convex(p1,n),convex(p2,m);
    int cnt=,j=;
    p1[n+]=p1[];p2[m+]=p2[];
    for(int i=;i<=n;++i){
    p[++cnt]=p1[i]+p2[j];
    while(j<=m&&crs(p2[j+]-p2[j],p1[i+]-p1[i])>=)
    p[++cnt]=p1[i]+p2[++j];
    }
    while(j<=m)p[++cnt]=p1[]+p2[j++];
    n=cnt;for(int i=;i<=n;++i)p[i]=p[i]-p[];
    for(int i=;i<=q;++i){
    Q.x=rd(),Q.y=rd();
    printf("%d\n",check(Q-p[]));
    }
    return ;
    }

LGP4577【JSOI2018】战争的更多相关文章

  1. [JSOI2018]战争

    题目描述 九条可怜是一个热爱读书的女孩子. 在她最近正在读的一本小说中,描述了两个敌对部落之间的故事.第一个部落有 nnn 个人,第二个部落有 mmm 个人,每一个人的位置可以抽象成二维平面上坐标为 ...

  2. P4557 [JSOI2018]战争

    首先可以题目描述的两个点集是两个凸包,分别设为A和B. 考虑一个向量w不合法的条件. 即存在b+w=a,其中a属于A,b属于B. 也就是a-b=w. 即对b取反后和a的闵可夫斯基和. 求出闵可夫斯基和 ...

  3. BZOJ5317:[JSOI2018]战争(闵可夫斯基和)

    令 \(a\in A,b\in B\) 则移动向量 \(\omega\) 使得存在 \(b+\omega=a\) 那么 \(\omega\) 需要满足 \(\omega=a−b\) 黑科技:闵可夫斯基 ...

  4. 洛谷P4557 [JSOI2018]战争(闵可夫斯基和+凸包)

    题面 传送门 题解 看出这是个闵可夫斯基和了然而我当初因为见到这词汇是在\(shadowice\)巨巨的\(Ynoi\)题解里所以压根没敢学-- 首先您需要知道这个 首先如果有一个向量\(w\)使得\ ...

  5. [JSOI2018]战争(闵可夫斯基和)

    害怕,可怜几何题 果然不会 题目就是说给你两个凸包,每次询问给你一个向量 \(c\) 问你能不能从两个凸包 \(A\) , \(B\) 里分别找到一个点 \(a\) , \(b\) 满足 \(a+c= ...

  6. 【LuoguP4557】[JSOI2018]战争

    题目链接 题意 给你两个点集. q次询问 , 每次把其中一个点集往一个方向移动 , 问两个点集的凸包还有没有交. Sol 闵可夫斯基和板子题. 把问题做如下转换: 我们本来两个凸包相交是相当于是对于移 ...

  7. 计算几何细节梳理&模板

    点击%XZY巨佬 向量的板子 #include<bits/stdc++.h> #define I inline using namespace std; typedef double DB ...

  8. HHHOJ #151. 「NOI模拟 #2」Nagisa

    计算几何板子题(我才没有拷板子的说--) 众所周知,三角形的重心坐标是\((\frac{x_1+x_2+x_3}{3},\frac{y_1+y_2+y_3}{3})\) 然后我们发现如果我们有一个点集 ...

  9. 【学习笔记】Minkowski和

    这还是个被我咕了N久的玩意 Minkowski和是一个奇怪的玩意 他长这样 $S={a+b \| a \in A , b \in B}$ AB可以是点集也可是向量集(显然) 他可以处理一些奇怪的东西 ...

  10. JSOI部分题解

    JSOI部分题解 JSOI2018 战争 问题转化为给定你两个凸包\(\mathbb S,\mathbb T\),每次独立的询问将\(\mathbb T\)中的每个点移动一个向量,问\(\mathbb ...

随机推荐

  1. P4562 [JXOI2018]游戏

    题面 题目描述 她长大以后创业了,开了一个公司. 但是管理公司是一个很累人的活,员工们经常背着可怜偷懒,可怜需要时不时对办公室进行检查. 可怜公司有 \(n\) 个办公室,办公室编号是 \(l\) 到 ...

  2. DataRow对象的RowState和DataRowVersion属性特点

    DataRow对象有两个比较重要的属性,分别是行状态(RowState)和行版本(DataRowVersion),通过这两个属性能够有效的管理表中的行.下面简要的介绍一下行状态和行版本的特点和关系. ...

  3. WebGL学习笔记四点一

    上一章是对图形的变换,这一章的第一节主要介绍了光栅化的过程,在创建多个颜色的三角形的过程中顶点着点器的过程如下 ,1.首先通过attribute的变量从javascript中获取数据,根据drawAr ...

  4. B3

    吴晓晖(组长) 过去两天完成了哪些任务 一些细节的debug,部分优化,算法中有关记录的部分 展示GitHub当日代码/文档签入记录 接下来的计划 推荐算法 还剩下哪些任务 组员:刘帅珍 过去两天完成 ...

  5. CXGRID用法(取行、列值;定位选中某行等等)[转]

    Delphi Cxgrid获取选中行列,排序规则,当前正在编辑的单元格内的值 cxGrid1DBTableView1.Controller.FocusedRowIndex 当前行号 cxGrid1DB ...

  6. sguf冲销脚本的实现

    1.该脚本为PCISS项目的sguf冲销脚本: DECLARE type typ_sguf_table is table of sguf_rowid_tab_1%rowtype ; sguf_tab ...

  7. [转帖] InfiniBand主流厂商和产品分析

    https://blog.csdn.net/swingwang/article/details/72935461 InfiniBand主流厂商和产品分析 2017年06月08日 22:03:46 Ha ...

  8. 【Java线程】SwingWorker的用法

    Swing应用程序员常见的错误是误用Swing事件调度线程(Event DispatchThread,EDT).他们要么从非UI线程访问UI组件:要么不考虑事件执行顺序:要么不使用独立任务线程而在ED ...

  9. HTML之绝对路径与相对路径

    路径指文件存放的位置,在网页中利用路径可以引用文件,插入图像.视频等.表示路径的方法有两种:相对路径,绝对路径.以下讨论均是在HTML环境下进行. 相对路径 相对路径是指目标相对于当前文件的路径,网页 ...

  10. YARN与MapReduce1的对比

    Apache YARN (Yet Another Resource Negotiator)从Hadoop2开始.YARN为集群提供资源管理和Applications的调度.YARN的API用于操作集群 ...