貌似这道题某人已经扔给我一个多星期了(雾)

首先要知道这样一点:凸包的面积可以直接用线段的有向面积和求得。

自己口胡的证明:单纯一条线段自身的叉积就是到原点与这条线段构成三角形的面积吧,那么加加减减之后就是凸包的面积了。。

所以我们可以单独考虑每条边的贡献。

显然一条边的贡献,就是在它 一侧 点的集合的 非空子集 的 数目。

所以我们枚举点然后极角排序扫一遍。

貌似除了自己手残写错了没有什么大坑?(雾)

 #include <bits/stdc++.h>
using namespace std;
typedef long double db;
typedef long long ll;
const ll mod = ;
const db eps=1e-;
const db pi=acos(-);
int sign(db k){if(k>-eps)return ;else if(k<-eps)return -; return ;}
int cmp(db k1,db k2){ return sign(k1-k2);}
struct point{
ll x,y;
db ang;
point operator+(const point &k1)const { return point{x+k1.x,y+k1.y};}
point operator-(const point &k1)const { return point{x-k1.x,y-k1.y};}
db getw(){ return atan2(1.0*y,1.0*x);}
};
ll cross(point k1,point k2){ return (k1.x*k2.y%mod-k1.y*k2.x%mod+*mod)%mod;}
bool cmp2(point a,point b){
return a.ang<b.ang;
}
ll f[];
void init(){
f[]=;
for(int i=;i<=;i++){
f[i]=f[i-]*%mod;
}
}
point p[];
int t,n;
point v[];
int cnt=;
ll slove(int id){
cnt=;
for(int i=;i<=n;i++){
if(i==id)continue;
v[cnt++]=point{p[i].x,p[i].y,(p[id]-p[i]).getw()};
}
for(int i=;i<cnt;i++){
v[i+cnt]=point{v[i].x,v[i].y,v[i].ang+*pi};
}
sort(v,v+*cnt,cmp2);
ll res=;
for(int l=,r=;l<cnt;l++){
while (r<*cnt&&v[r].ang-v[l].ang<pi){
r++;
}
res+=cross(p[id],v[l])*((f[r-l-]-+mod)%mod)%mod;
res%=mod;
}
return res;
}
int main(){
//freopen("zoj3871.in","r",stdin);
init();
scanf("%d",&t);
while (t--){
scanf("%d",&n);
ll ans = ;
for(int i=;i<=n;i++){
scanf("%lld%lld",&p[i].x,&p[i].y);
}
for(int i=;i<=n;i++) {
ans += slove(i);
ans%=mod;
}
printf("%lld\n",ans);
}
}

zoj 3871的更多相关文章

  1. ZOJ 3871 Convex Hull(计算几何、凸包)

    题意:给n个点,|x[i]|,|y[i]| <= 1e9.求在所有情况下的子集下(子集点数>=3),凸包的面积和. 这题主要有几个方面,一个是凸包的面积,可以直接用线段的有向面积和求得,这 ...

  2. ZOJ People Counting

    第十三届浙江省大学生程序设计竞赛 I 题, 一道模拟题. ZOJ  3944http://www.icpc.moe/onlinejudge/showProblem.do?problemCode=394 ...

  3. ZOJ 3686 A Simple Tree Problem

    A Simple Tree Problem Time Limit: 3 Seconds      Memory Limit: 65536 KB Given a rooted tree, each no ...

  4. ZOJ Problem Set - 1394 Polar Explorer

    这道题目还是简单的,但是自己WA了好几次,总结下: 1.对输入的总结,加上上次ZOJ Problem Set - 1334 Basically Speaking ac代码及总结这道题目的总结 题目要求 ...

  5. ZOJ Problem Set - 1392 The Hardest Problem Ever

    放了一个长长的暑假,可能是这辈子最后一个这么长的暑假了吧,呵呵...今天来实验室了,先找了zoj上面简单的题目练练手直接贴代码了,不解释,就是一道简单的密文转换问题: #include <std ...

  6. ZOJ Problem Set - 1049 I Think I Need a Houseboat

    这道题目说白了是一道平面几何的数学问题,重在理解题目的意思: 题目说,弗雷德想买地盖房养老,但是土地每年会被密西西比河淹掉一部分,而且经调查是以半圆形的方式淹没的,每年淹没50平方英里,以初始水岸线为 ...

  7. ZOJ Problem Set - 1006 Do the Untwist

    今天在ZOJ上做了道很简单的题目是关于加密解密问题的,此题的关键点就在于求余的逆运算: 比如假设都是正整数 A=(B-C)%D 则 B - C = D*n + A 其中 A < D 移项 B = ...

  8. ZOJ Problem Set - 1001 A + B Problem

    ZOJ ACM题集,编译环境VC6.0 #include <stdio.h> int main() { int a,b; while(scanf("%d%d",& ...

  9. zoj 1788 Quad Trees

    zoj 1788 先输入初始化MAP ,然后要根据MAP 建立一个四分树,自下而上建立,先建立完整的一棵树,然后根据四个相邻的格 值相同则进行合并,(这又是递归的伟大),逐次向上递归 四分树建立完后, ...

随机推荐

  1. .NET的前世今生与将来

    笔者注 谨以此文纪念我敬重的2016年9月17日去世的 装配脑袋 逝世两周年 让大家久等了,前后花了1年的时间,几经改版,终于完成撰写了一万字长文,回顾和展望.NET这16年来的成功与失败.最终能成文 ...

  2. C# 发送消息SendKeys、SendMessage、keybd_event的用法

    一.C#中SendKeys的用法 功能:将一个或多个按键消息发送到活动窗口,就如同在键盘上进行输入一样. 语法: SendKeys.Send(string keys); SendKeys.SendWa ...

  3. 已安装nginx动态添加模块

    说明:已经安装好的nginx,需要添加一个未被编译安装的模块,需要怎么弄呢? 具体:这里以安装第三方ngx_http_google_filter_module模块为例nginx的模块是需要重新编译ng ...

  4. 使用ScriptableObject创建.asset文件

    .asset一般用来存储一些配置,比如SDK初始化的相关参数. using System.Collections.Generic; using UnityEngine; namespace XXX { ...

  5. 如何确定Isilon cluster的网卡类型是40GbE的还是10GbE的

    可以使用isi upgrade cluster firmware devices命令. 从命令行输出可以看到,当前的cluster使用的是40G的前端网卡. 如果是10G网卡,输出结果应当是如下的样子 ...

  6. uc浏览器视频缓存合并工具

    1.该软件用于将uc浏览器中零散的视频缓存切片处理成完整的视频文件. 开发语言:C#开发工具: Visual Studio 2017 Community 实例图示: 程序代码下载地址 windows ...

  7. PhpStorm配置SVN的完整方法

    1.安装SVN时注意选择“command line client tools"默认是不安装的 2.设置系统环境变量 3.在PhpStorm上设置如下 4.然后通过VCS就可以上传导入你的工程 ...

  8. Linux 修改时区

    CentOS 7修改方式如下: # lsb_release -a  --查看系统版本-CentOS Linux release 7.6 # timedatectl     --查看当前系统时区# ls ...

  9. python3 利用正则获取网页中的想保存下来的内容

    需要获取某个网页中表格部分中某个产品的成份 分析在html中成份的元素代码 <a href="/composition/4c3060178d1184935a48c4e51be4f63f ...

  10. vue及ElementUI环境搭建

    1. nodejs安装及npm安装 下载地址:https://nodejs.org/en/download/ 选择windows Installer 下载完成后 运行node-v8.11.1-x64. ...