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的更多相关文章

  1. 【(好题)组合数+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 ...

  2. 【双向bfs】2017多校训练十 HDU 6171 Admiral

    [题意] 现在给出一个三角矩阵,如果0编号的在点(x,y)的话,可以和(x+1,y),(x-1,y),(x+1,y+1),(x-1,y-1)这些点进行交换. 我们每一次只能对0点和其他点进行交换.问最 ...

  3. 【思维】2017多校训练七 HDU6121 Build a tree

    http://acm.hdu.edu.cn/showproblem.php?pid=6121 [题意] 询问n个结点的完全k叉树,所有子树结点个数的异或和是多少 [思路] 一棵完全K叉树,对于树的每一 ...

  4. 【构造+DFS】2017多校训练三 HDU 6060 RXD and dividing

    acm.hdu.edu.cn/showproblem.php?pid=6060 [题意] 给定一棵以1为根的树,把这颗树除1以外的结点划分为k个集合(可以有空集),把1加入划分后的集合 每个集合的结点 ...

  5. 【链表】2017多校训练三 HDU 6058 Kanade's sum

    acm.hdu.edu.cn/showproblem.php?pid=6058 [题意] 给定一个排列,计算 [思路] 计算排列A中每个数的贡献,即对于每个ai,计算有ni个区间满足ai是区间中的第k ...

  6. 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 ...

  7. hdu 6127 Hard challenge(极角/角度排序+枚举+结构体排序新写法)

    Hard challenge Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Others) ...

  8. hdu 6127 : Hard challenge (2017 多校第七场 1008)(计算几何)

    题目链接 题意:二维平面上有n个点(没有重叠,都不在原点,任意两点连线不过原点),每个点有一个权值,用一条过原点的直线把他们划分成两部分,使两部分的权值和的乘积最大.输出最大的乘积. 极角排序后,将原 ...

  9. 2017多校第7场 HDU 6127 Hard challenge 极角排序,双指针

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6127 题意:平面直角坐标系上有n个整点,第i个点有一个点权val​,坐标为(xi,yi),其中不存在任 ...

随机推荐

  1. Java中枚举类型Enum的一种使用方式

    枚举类定义如下: public enum Status { SCUUESS("1", "成功"), FAILED("2", "失败 ...

  2. 使用Cordova将您的前端JavaScript应用打包成手机原生应用

    假设我用JavaScript和HTML开发了一个前端应用,我想把该应用打包成能直接在手机上安装和运行(不通过浏览器)的原生应用,例如像下面这样.对应用的用户来说,他们得到的用户体验和真正的用Andro ...

  3. Objective-C分类 (category)和扩展(Extension) 的区别

    http://blog.csdn.net/yhawaii/article/details/6992094 http://blog.163.com/wangy_0223/blog/static/4501 ...

  4. uaf-湖湘杯2016game_学习

    0x00 分析程序 根据分析,我们可以得到以下重要数据结构 0x01 发现漏洞 1.在武器使用次数耗光后,程序会把存储该武器的堆块free,在free的时候没有清空指针,造成悬挂指针 2.commen ...

  5. hibernate4整合spring3.1的过程中的异常问题

    (1)hibernate4整合spring3.1的过程中,发现了java.lang.NoClassDefFoundError: Lorg/hibernate/cache/CacheProvider异常 ...

  6. jquery的同步和异步

    之前一直在写JQUERY代码的时候遇到AJAX加载数据都需要考虑代码运行顺序问题.最近的项目用了到AJAX同步.这个同步的意思是当JS代码加载到当前AJAX的时候会把页面里所有的代码停止加载,页面出去 ...

  7. shell脚本,一个经典题目。

    [root@localhost wyb]# cat zhuijiu.sh #!/bin/bash #.写一个脚本执行后,输入名字,产生随机数01-99之间的数字. #.如果相同的名字重复输入,抓到的数 ...

  8. 五. web开发基础

    一.HTML 二.CSS 三.JavaScript 四.web框架 1.web框架本质 众所周知,对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端 ...

  9. java在线聊天项目 实现基本聊天功能后补充的其他功能详细需求分析 及所需要掌握的Java知识基础 SWT的激活方法,swt开发包下载,及破解激活码

    补充聊天项目功能,做如下需求分析: 梳理项目开发所需的必要Java知识基础 GUI将使用更快速的swt实现 SWT(Standard Widget Toolkit) Standard Widget T ...

  10. (转)python之禅

    凡是用过 Python的人,基本上都知道在交互式解释器中输入 import this 就会显示 Tim Peters 的 The Zen of Python,但它那偈语般的语句有点令人费解,所以我想分 ...