【极角排序+双指针线性扫】2017多校训练七 HDU 6127 Hard challenge
acm.hdu.edu.cn/showproblem.php?pid=6127
【题意】
- 给定平面直角坐标系中的n个点,这n个点每个点都有一个点权
- 这n个点两两可以连乘一条线段,定义每条线段的权值为线段两端点点权的乘积
- 现在要过原点作一条直线,要求这条直线不经过任意一个给定的点
- 在所有n个点两两连成的线段中,计算与这条直线有交点的线段的权值和
- 最大化这个权值和并输出
- 题目保证,给定的n个点不重合且任意两个点的连线不经过原点
【思路】
- 一条经过原点的直线把n个点分成两个半平面A,B
- 假设A中的点权分别为a1,a2....an;B中的点权分别为b1,b2,......bm。则结果为sumA*sumB
- 极角排序,枚举每个起点,线性扫一圈,计算半平面的点权之和,不断更新最优值
【AC】
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cmath>
#include<algorithm> using namespace std;
typedef long long ll;
const int maxn=5e4+;
int n;
double xx[maxn];
double yy[maxn];
ll val[maxn];
ll ans[maxn]; double dis(double x1,double y1,double x2,double y2){return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));}
const double eps = 1e-;
struct Point
{
double x;
double y;
ll val;
double dis;
double alf;
Point(){}
Point(double _x,double _y):x(_x),y(_y){}
Point(double _x,double _y,ll _val):x(_x),y(_y),val(_val){}
Point operator -(const Point &t) const
{
return Point(x-t.x,y-t.y);
}
double operator ^(const Point &t)const
{
return (x*t.y)-(y*t.x);
}
}p[maxn];
Point o(0.0,0.0);
bool cmp(const Point &a, const Point &b)//先按象限排序,再按极角排序,再按远近排序
{
if (a.y == && b.y == && a.x*b.x <= )return a.x>b.x;
if (a.y == && a.x >= && b.y != )return true;
if (b.y == && b.x >= && a.y != )return false;
if (b.y*a.y <= )return a.y>b.y;
return ((a-o)^(b-o))> 0.0 || (((a-o)^(b-o)) == 0.0 && a.x < b.x);
} int main()
{
int T;
scanf("%d",&T);
while(T--)
{
memset(ans,,sizeof(ans));
scanf("%d",&n);
ll sum=;
for(int i=;i<n;i++)
{
scanf("%lf%lf%I64d",&xx[i],&yy[i],&val[i]);
p[i]=Point(xx[i],yy[i],val[i]);
sum+=val[i];
}
sort(p,p+n,cmp);
int l=;
ll res;
ans[]+=p[].val;
for(int i=;i<n;i++)
{
if(i>) ans[i]=ans[i-]-p[i-].val;
while(((p[i]-o)^(p[l]-o))>)
{
ans[i]+=p[l].val;
l=(l+)%n;
}
if(i==) res=ans[i]*(sum-ans[i]);
else res=max(res,ans[i]*(sum-ans[i]));
}
printf("%I64d\n",res);
}
return ;
}
极角排序+线性扫模板
【模板】
bool cmp(const Point &a, const Point &b)//先按象限排序,再按极角排序,再按远近排序
{
if (a.y == && b.y == && a.x*b.x <= )return a.x>b.x;
if (a.y == && a.x >= && b.y != )return true;
if (b.y == && b.x >= && a.y != )return false;
if (b.y*a.y <= )return a.y>b.y;
return ((a-o)^(b-o))> 0.0 || (((a-o)^(b-o)) == 0.0 && a.x < b.x);
}
极角排序,o是中心点
int l=;
ll res;
// ans[0]+=p[0].val;
for(int i=;i<n;i++)
{
//if(i>0) ans[i]=ans[i-1]-p[i-1].val;
while(((p[i]-o)^(p[l]-o))>)
{
// 必要的运算
l=(l+)%n;
}
//这里更新答案
}
线性扫
【极角排序+双指针线性扫】2017多校训练七 HDU 6127 Hard challenge的更多相关文章
- 【(好题)组合数+Lucas定理+公式递推(lowbit+滚动数组)+打表找规律】2017多校训练七 HDU 6129 Just do it
http://acm.hdu.edu.cn/showproblem.php?pid=6129 [题意] 对于一个长度为n的序列a,我们可以计算b[i]=a1^a2^......^ai,这样得到序列b ...
- 【双向bfs】2017多校训练十 HDU 6171 Admiral
[题意] 现在给出一个三角矩阵,如果0编号的在点(x,y)的话,可以和(x+1,y),(x-1,y),(x+1,y+1),(x-1,y-1)这些点进行交换. 我们每一次只能对0点和其他点进行交换.问最 ...
- 【思维】2017多校训练七 HDU6121 Build a tree
http://acm.hdu.edu.cn/showproblem.php?pid=6121 [题意] 询问n个结点的完全k叉树,所有子树结点个数的异或和是多少 [思路] 一棵完全K叉树,对于树的每一 ...
- 【构造+DFS】2017多校训练三 HDU 6060 RXD and dividing
acm.hdu.edu.cn/showproblem.php?pid=6060 [题意] 给定一棵以1为根的树,把这颗树除1以外的结点划分为k个集合(可以有空集),把1加入划分后的集合 每个集合的结点 ...
- 【链表】2017多校训练三 HDU 6058 Kanade's sum
acm.hdu.edu.cn/showproblem.php?pid=6058 [题意] 给定一个排列,计算 [思路] 计算排列A中每个数的贡献,即对于每个ai,计算有ni个区间满足ai是区间中的第k ...
- 2017ACM暑期多校联合训练 - Team 7 1008 HDU 6127 Hard challenge (极角排序)
题目链接 Problem Description There are n points on the plane, and the ith points has a value vali, and i ...
- hdu 6127 Hard challenge(极角/角度排序+枚举+结构体排序新写法)
Hard challenge Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 524288/524288 K (Java/Others) ...
- hdu 6127 : Hard challenge (2017 多校第七场 1008)(计算几何)
题目链接 题意:二维平面上有n个点(没有重叠,都不在原点,任意两点连线不过原点),每个点有一个权值,用一条过原点的直线把他们划分成两部分,使两部分的权值和的乘积最大.输出最大的乘积. 极角排序后,将原 ...
- 2017多校第7场 HDU 6127 Hard challenge 极角排序,双指针
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6127 题意:平面直角坐标系上有n个整点,第i个点有一个点权val,坐标为(xi,yi),其中不存在任 ...
随机推荐
- NBUT 1116 Flandre's Passageway (LIS变形)
题意: 给一个有n*m格子的矩形,设每格边长100,要从(1,1)走到(n,m)需要耗(n+m)*100,但是其中有一些格子是可以直接穿过的,也就是走对角线,是100*根号2长,给出k个可以穿过的格子 ...
- Codeforces Round #318 (Div. 2) C Bear and Poker (数学)
简单题,求一下所有数的2和3的幂是任意调整的,把2和3的因子除掉以后必须相等. 求lcm,爆了long long.我得好好反省一下,对连乘不敏感 #include<bits/stdc++.h&g ...
- HDU 6052 To my boyfriend(容斥+单调栈)
题意:对于一个n*m的方格,每个格子中都包含一种颜色,求出任意一个矩形包含不同颜色的期望. 思路: 啊啊啊啊啊,补了两天,总算A了这道题了,简直石乐志,前面的容斥还比较好写,后面的那个>13那个 ...
- HDU 6041 I Curse Myself(点双联通加集合合并求前K大) 2017多校第一场
题意: 给出一个仙人掌图,然后求他的前K小生成树. 思路: 先给出官方题解 由于图是一个仙人掌,所以显然对于图上的每一个环都需要从环上取出一条边删掉.所以问题就变为有 M 个集合,每个集合里面都有一堆 ...
- ucosii(2.89)mutex 应用要点
mutex 的创建在于共享资源打交道是可以可以保证满足互斥条件:1,必须保证继承优先级要高于可能与相应共享资源打交道的任务中优先级最高的优先级.2,不要将占有Mutex的任务挂起,也不要让占有mute ...
- 关于highchts X时间轴比设置时间相差好几个小时的解决
经过一番查询和研究发现,在曲线图里,x轴的UNIX时间戳是要乘以1000的(通过在线的UNIX转换,结果与原来没有乘以1000的时间戳相差甚远),不然显示的时间会有很大的误差,真是百思不得其解. 另外 ...
- Mac终端(Terminal)自定义颜色,字体,背景
使用Mac作为开发机的时候,苹果终端自带的颜色黑白,字体又小,看起来确实不是很舒服.那推荐大家使用Solarized配色方案.Solarized 是目前最完整的 Terminal/Editor/IDE ...
- MySQL查询当天数据以及大量查询时提升速度
select * from 表名 where to_days(字段名) = to_days(now()) 一.数据库设计方面1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 ord ...
- 题解 P1189 SEARCH
(传送门)[https://www.luogu.org/problemnew/show/P1189] 先反省一波:我以后再也不用getchar()+scanf了(日常爆零) 算是比较裸的搜索吧,在下用 ...
- 关于Java IO流学习总结
一.IO流的三种分类方式 1.按流的方向分为:输入流和输出流 2.按流的数据单位不同分为:字节流和字符流 3.按流的功能不同分为:节点流和处理流 二.IO流的四大抽象类: 字符流:Reader ...