题目描述

  对于一个平面上点的集合P={(xi,yi )},定义集合P的面积F(P)为点集P的凸包的面积。
  对于两个点集A和B,定义集合的和为:
  A+B={(xiA+xjB,yiA+yjB ):(xiA,yiA )∈A,(xjB,yjB )∈B}
  现在给定一个N个点的集合A和一个M个点的集合B,求2F(A+B)。

输入格式

 第一行包含用空格隔开的两个整数,分别为N和M;
  第二行包含N个不同的数对,表示A集合中的N个点的坐标;
  第三行包含M个不同的数对,表示B集合中的M个点的坐标。

 

输出格式

 一共输出一行一个整数,2F(A+B)。


数据规模和约定
  对于30%的数据满足N ≤ 200,M ≤ 200;
  对于100%的数据满足N ≤ 10^5,M ≤ 10^5,|xi|, |yi| ≤ 10^8。

  • 题解:

    • 如果一个点成为了和$A+B$的凸包,那么一定同时在$A$和$B$的凸包上;
    • 设$A+B$看成把凸包$A$平移后放在凸包$B$上,发现在两个凸包上组合成新的凸包的点对是单调的;
    • 类似$graham$维护两个指针;
    • 不太好说,附图,但是建议自己$YY$:
    •  #include<bits/stdc++.h>
      #define ll long long
      using namespace std;
      const int N=;
      int n,m,cnt1,cnt2,Cnt;
      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<<)+(x<<)+c-'';c=gc();}
      return x*f;
      }
      struct poi{
      int x,y;
      poi(int _x=,int _y=):x(_x),y(_y){};
      poi operator +(const poi&A)const{return poi(x+A.x,y+A.y);}
      poi operator -(const poi&A)const{return poi(x-A.x,y-A.y);}
      bool operator <(const poi&A)const{return x==A.x?y<A.y:x<A.x;}
      }p1[N],p2[N],q1[N],q2[N],Q[N];
      ll crs(poi A,poi B){return (ll)A.x*B.y-(ll)A.y*B.x;}
      void convex(poi *p,poi *q,int&tot,int&cnt){
      if(tot==){q[cnt=]=q[]=p[];return;}
      sort(p+,p+tot+);
      q[cnt=]=p[];
      for(int i=;i<=tot;i++){
      while(cnt> && crs(q[cnt]-q[cnt-],p[i]-q[cnt])<=)cnt--;
      q[++cnt]=p[i];
      }
      int now=cnt;
      for(int i=tot-;i;i--){
      while(cnt>now && crs(q[cnt]-q[cnt-],p[i]-q[cnt])<=)cnt--;
      q[++cnt]=p[i];
      }
      cnt--;
      }
      int main(){
      #ifndef ONLINE_JUDGE
      freopen("bzoj2564.in","r",stdin);
      freopen("bzoj2564.out","w",stdout);
      #endif
      n=rd();m=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,q1,n,cnt1);
      convex(p2,q2,m,cnt2);
      int i,j;
      for(i=,j=;i<=cnt1;i++){
      Q[++Cnt]=q1[i]+q2[j];
      while(j<=cnt2&&crs(q2[j+]-q2[j],q1[i+]-q1[i])>){
      Q[++Cnt]=q1[i]+q2[++j];
      }
      }
      for(;j<=cnt2+;j++)Q[++Cnt]=q1[i]+q2[j];
      Cnt--;
      ll ans=;
      for(i=;i<Cnt;i++)ans += crs(Q[i]-Q[],Q[i+]-Q[]);
      printf("%lld\n",ans);
      return ;
      }

      bzoj2564

bzoj2564集合的面积的更多相关文章

  1. bzoj2564 集合的面积

    Description 对于一个平面上点的集合P={(xi,yi )},定义集合P的面积F(P)为点集P的凸包的面积. 对于两个点集A和B,定义集合的和为: A+B={(xiA+xjB,yiA+yjB ...

  2. bzoj2564: 集合的面积(闵可夫斯基和 凸包)

    题面 传送门 题解 花了一个下午的时间调出了一个稍微能看的板子--没办法网上的板子和咱的不太兼容-- 首先有一个叫做闵可夫斯基和的东西,就是给你两个点集\(A,B\),要你求一个点集\(C=\{x+y ...

  3. BZOJ2564: 集合的面积(闵可夫斯基和 凸包)

    题意 题目链接 Sol 这个东西的学名应该叫"闵可夫斯基和".就是合并两个凸包 首先我们先分别求出给出的两个多边形的凸包.合并的时候直接拿个双指针扫一下,每次选最凸的点就行了. 复 ...

  4. bzoj 2564 集合的面积

    Description 对于一个平面上点的集合P={(xi,yi )},定义集合P的面积F(P)为点集P的凸包的面积. 对于两个点集A和B,定义集合的和为: A+B={(xiA+xjB,yiA+yjB ...

  5. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  6. UVALive 4794 Sharing Chocolate

    Sharing Chocolate Chocolate in its many forms is enjoyed by millions of people around the world ever ...

  7. [opencv]二维码识别开发流程及问题复盘总结

    项目复盘总结 开发需求: 在桌面机器人(向下俯视)摄像头拍摄到的图像中做条形码识别与二维码识别. 条形码在图像固定位置,二维码做成卡片的形式在固定区域内随意摆放. 开发环境及相关库:ubuntu 18 ...

  8. 计算照片的面积(WPF篇)

    昨天,老周突发其想地给大伙伴们说了一下UWP应用中计算照片面积的玩法,而且老周也表示会提供WPF版本的示例.所以,今天就给大伙们补上吧. WPF是集成在.net框架中,属于.net的一部分,千万不要跟 ...

  9. 计算照片的面积(UWP篇)

    今天先说UWP应用程序上计算照片面积的方法,改天有空,再说说WPF篇. 其实计算照片面积的原理真TMD简单,只要你有本事读到照片的像素高度和宽度,以及水平/垂直方向上的分辨率(DPI)就可以了.计算方 ...

随机推荐

  1. 用shell实现bat批处理的pause命令-追加改进

    我参考了这个文章:用shell实现bat的pause http://linux-wiki.cn/wiki/zh-hans/%E7%94%A8shell%E5%AE%9E%E7%8E%B0bat%E7% ...

  2. FICO(费埃哲)评分系统有什么优缺点?在国内的发展怎么样?

    权威回答: FICO的优点很明显: 在美国数据库较全面.一般存储有最近7-10年的个人信用记录,包括银行信用.商业信用甚至保险等. 客观性.计算机自动完成评估工作,克服人为操作的失误. 快捷性.出结果 ...

  3. xml配置文件特殊符号的处理方法

    2017.7.19遇到问题:偶然出现“认证失败,请重新登录”的现象   在xml中英文问号“?”是可以被正常解析的,但是以下这几种符号是不能正常解析的:分别是“&”.“<”.“>” ...

  4. Scrum Meeting 报告

    Scrum Meeting 报告 ----团队项目所需时间估计以及任务分配 由于能力有限,我们还不能构架好一个大框架.但是初步可以完成任务的流程和分配.任务所需要的具体实现可以参看<学霸系统的N ...

  5. 2018-2019-20172321 《Java软件结构与数据结构》第八周学习总结

    2018-2019-20172321 <Java软件结构与数据结构>第八周学习总结 教材学习内容总结 第12章 优先队列与堆 一.概述 堆 堆的前提就是他首先是一个完全二叉树,其次就是满足 ...

  6. Leetcode题库——13.罗马数字转整数

    @author: ZZQ @software: PyCharm @file: Luoma2Int.py @time: 2018/9/16 17:06 要求: 罗马数字转数字 字符 数值 I 1 V 5 ...

  7. Teamwork(The third day of the team)

    在确定了第一个spring后我们就开始了各自的工作,不过由于大家都在专注于自己的工作并且由于近段时间的作业及各方面的事情都很多,没有来得及每天都更新一个博客,因此,我们现在把落下的博客都补上,很多事情 ...

  8. TCP 连接管理

    实验代码和内容:https://github.com/ZCplayground/Understanding-Unix-Linux-Programming/tree/master/11.socket 明 ...

  9. [转帖]NVMe到底是什么?用它的SSD有啥优势?

    NVMe到底是什么?用它的SSD有啥优势? 2015-8-20 14:00  |  作者:Strike   |  关键字:NVMe,SSD,PCI-E SSD,超能课堂 分享到       有关注SS ...

  10. Mysql innodb 间隙锁 (转)

    MySQL InnoDB支持三种行锁定方式: 行锁(Record Lock):锁直接加在索引记录上面. 间隙锁(Gap Lock):锁加在不存在的空闲空间,可以是两个索引记录之间,也可能是第一个索引记 ...