n<=2000,肯定没有办法把所有三角形找出来全判一遍

对于三角形的三个角,分别计算贡献,锐角的贡献是1倍面积,钝角的贡献是-2倍面积,这样算出角的贡献之后除以3就可以了

每次选择一个点为中心点,极角排序,维护一个锐角和钝角的坐标和,边扫边算贡献

#include <bits/stdc++.h>
#define ll long long
#define big __int128
#define eps 1e-8
#define mod 998244353
using namespace std;
const int maxn = ;
int sgn(double x)
{
if (fabs(x) < eps)
return ;
if (x < )
return -;
return ;
}
struct Point
{
big x, y;
Point() {}
Point(big _x, big _y)
{
x = _x;
y = _y;
}
Point operator+(const Point &b) const
{
return Point(x + b.x, y + b.y);
}
Point operator-(const Point &b) const
{
return Point(x - b.x, y - b.y);
}
big operator*(const Point &b) const
{
return x * b.x + y * b.y;
}
big operator^(const Point &b) const
{
return x * b.y - y * b.x;
}
void Mod()
{
bool tx = false, ty = false;
if (x < )
{
x = -x;
tx = true;
}
if (y < )
{
y = -y;
ty = true;
}
x %= mod;
y %= mod;
if (tx)
x = -x;
if (ty)
y = -y;
}
int getxx()
{
if (x > && y >= )
return ;
if (x <= && y > )
return ;
if (x < && y <= )
return ;
if (x >= && y < )
return ;
return ;
}
} a[maxn],del[maxn];
bool cmp(Point &a,Point &b){
if(a.getxx() != b.getxx()){
return a.getxx() < b.getxx();
}else{
return (a^b)>;
}
}
int n;
big ans;
void gao(int id){
Point now = a[id];
int m = ;
for(int i = ;i <= n;i++){
if(i==id)continue;
del[++m] = a[i]-now;
//del[m].Mod();
}
if(m<=)return;
sort(del+,del++m,cmp);
int p1 = ,p2 = ;
Point s1=del[],s2=del[],ts1,ts2;
for(int i = ;i <= m;i++){
int nxt;
while(true){
nxt = p1+;
if(nxt>m)nxt=;
if(nxt==i)break;
if(!((del[i]^del[nxt])>=&&(del[i]*del[nxt])>))break;
if((del[i]^del[nxt])==&&(del[i]^del[p1])!=)break;
p1=nxt;s1=s1+del[p1];
}
while(true){
nxt = p2+;
if(nxt>m)nxt=;
if(nxt==i)break;
if(!((del[i]^del[nxt])>=))break;
if((del[i]^del[nxt])==&&(del[i]^del[p2])!=)break;
p2=nxt;s2=s2+del[p2];
}
ts1=s1;ts2=s2-s1;ts1.Mod();ts2.Mod();
ans+=(del[i]^ts1);ans %= mod;
ans-=(del[i]^ts2)%mod*2ll%mod;
ans=(ans+mod)%mod;
if(p1==i){p1++;s1=s1+del[p1];}s1=s1-del[i];
if(p2==i){p2++;s2=s2+del[p2];}s2=s2-del[i];
} }
int main()
{
int T;
scanf("%d",&T);
big inv = (mod+)/;
while (T--)
{
scanf("%d",&n);
ans=;
for (int i = ; i <= n; i++)
{
ll x, y;
scanf("%lld%lld",&x,&y);
a[i] = Point(x, y);
} for(int i= ;i <= n;i++){
gao(i);
}
ans=(ans*inv)%mod;
ll t = ans;
printf("%lld\n",t);
}
return ;
}

hihoCoder#1879 : Rikka with Triangles (计算几何)的更多相关文章

  1. hihoCoder 1040 矩形判断(计算几何)

    http://hihocoder.com/problemset/problem/1040 首先判断四条线段是否相交,给出八个点,如果有一些点重合,并且不同坐标的点只有4个的话,表示可以构成四边形. 然 ...

  2. hdu 5784 How Many Triangles 计算几何,平面有多少个锐角三角形

    How Many Triangles 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5784 Description Alice has n poin ...

  3. hihocoder #1040 矩形判断(计算几何问题 给8个点的坐标,能否成为一个矩形 【模板思路】)

    #1040 : 矩形判断 时间限制:1000ms 单点时限:1000ms 内存限制:256MB 描述 给出平面上4条线段,判断这4条线段是否恰好围成一个面积大于0的矩形. 输入 输入第一行是一个整数T ...

  4. hdu-5784 How Many Triangles(计算几何+极角排序)

    题目链接: How Many Triangles Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  5. hihocoder #1456 : Rikka with Lattice(杜教筛)

    hihocoder #1456 : Rikka with Lattice(杜教筛) 题意 : 给你一个\(n*m\)方格图,统计上面有多少个格点三角形,除了三个顶点,不覆盖其他的格点(包括边和内部). ...

  6. hihoCoder #1646 : Rikka with String II(容斥原理)

    题意 给你 \(n\) 个 \(01\) 串 \(S\) ,其中有些位置可能为 \(?\) 表示能任意填 \(0/1\) .问对于所有填法,把所有串插入到 \(Trie\) 的节点数之和(空串看做根节 ...

  7. HihoCoder#1279 : Rikka with Sequence(dp 枚举子集 二进制 神仙题)

    题意 题目链接 Sol 不愧是dls出的比赛啊,265个交了题的人只有8个有分Orz 做完这题,,感觉自己的位运算dp姿势升华了... 首先最裸的dp应该比较好想,设\(f[i][j][k]\)表示前 ...

  8. hihocoder-1453-Rikka with Tree

    #Hihocoder 1453 : Rikka with Tree 时间限制:10000ms 单点时限:1000ms 内存限制:256MB   source: https://hihocoder.co ...

  9. 【CF528E】Triangles 3000(计算几何)

    [CF528E]Triangles 3000(计算几何) 题面 CF 平面上有若干条直线,保证不平行,不会三线共点. 求任选三条直线出来围出的三角形的面积的期望. 题解 如果一定考虑直接计算这个三角形 ...

随机推荐

  1. 一、Signalr WebApi客服-客户链接+Redis

    一.前端客服代码 <!doctype html> <html> <head> <meta charset="utf-8"> < ...

  2. ubuntu 设置apt-get 代理

    1 添加apt-get 代理配置文件 sudo vi /etc/apt/apt.conf.d/proxy.conf 2 添加内容 Acquire::http::Proxy "http://w ...

  3. 微信支付-无法识别qrcode生成的二维码图片

    1.开始使用 table方式,但是还是无法识别二维码  http://www.cnblogs.com/staticed/p/8549316.html var code_url = data.code_ ...

  4. GET和POST请求的区别和使用场景

    本质上的区别: GET请求.处理.响应过程中只是产生一个TCP数据包,而POST请求会产生两个TCP数据包.    更具体地说,GET请求过程中头和请求正文数据一起到服务器端, 而POST请求过程中, ...

  5. js对象的创建模式

    方式一: Object构造函数模式 * 套路: 先创建空Object对象, 再动态添加属性/方法 * 适用场景: 起始时不确定对象内部数据 * 问题: 语句太多 /* 一个人: name:" ...

  6. ssh复制公钥成功后仍需输入密码

    1,网上说权限问题 登录流程: 被登录机器的文件权限: //用户权限 chmod 700 /home/username //.ssh文件夹权限 chmod 700 ~/.ssh/ // ~/.ssh/ ...

  7. Linux基础教程 linux下cat 命令使用详解

    cat命令的用途是连接文件或标准输入并打印.这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用. 1.命令格式: cat [选项] [文件] ...

  8. Linux基础教程 linux awk内置变量使用介绍

    awk是个优秀文本处理工具,可以说是一门程序设计语言.下面是兄弟连Linux培训 给大家介绍的awk内置变量. 一.内置变量表 属性 说明 $0 当前记录(作为单个变量) $1~$n 当前记录的第n个 ...

  9. Codeforces 950C Zebras ( 贪心 && 模拟 )

    题意 : 给出一个 01 串,要求你将其分隔出若干个子序列 ( 每个数字只能属于某一个子序列 ) ,子序列必须满足由 0 开头和结尾,且中间需 01 交替构成.若无法做到,则输出 -1. 分析 :  ...

  10. JUnit——Annotation

    Annotation是对属性,方法或者类做一个标记  比如@override表示复写了父类中的方法 [1]@Test: 测试方法(说明该方法为测试方法) a)(expected=XXException ...