hdu6127

题意

二维平面上存在一些点,每个点都有权值,任意两点组成的线段的权值为这两点权值的乘积,选定一条经过原点的直线,问怎样使得它经过的线段的权值之和最大。

分析

题目等价于用一条直线将平面上的所有点分成两部分,那么答案就是两部分点的权值和的乘积。

比如说一条与 \(y\) 轴重合的直线,它左边有点的权值 \(w_1, w_2, w_3\) ,右边 \(w_4, w_5\) ,那么这种情况下权值之和就是 \((w_1 + w_2 + w_3) * (w_4 + w_5)\) 。

计算出所有点的斜率,一三象限归为一类,二四象限归为一类,给斜率排序。

以一三象限为例,上部分一定包括第二象限的点的权值之和,下部分一定包括第四象限的点的权值之和,将斜率从小到大排序的话,那么初始状态上部分包括第一象限的点的权值之和,下部分包括第三象限的点的权值之和。枚举排序后的点,如果斜率最小的点在第一象限,把它从上部分删去,加入到下部分,计算权值之和,更新答案即可。

code

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
struct Point {
ll x, y, w;
double k;
Point() {}
Point(ll x, ll y, ll w, double k) : x(x), y(y), w(w), k(k) {}
bool operator<(const Point&p) const {
return k < p.k;
}
};
vector<Point> p1, p2;
int main() {
int T;
scanf("%d", &T);
while(T--) {
int n;
scanf("%d", &n);
ll wei[4]; // 处于坐标轴上的点
memset(wei, 0, sizeof wei);
p1.clear(); p2.clear();
ll xian1 = 0, xian2 = 0, xian3 = 0, xian4 = 0; // 每个象限点的权值之和
for(int i = 0; i < n; i++) {
ll x, y, w;
scanf("%lld%lld%lld", &x, &y, &w);
if(x == 0 && y > 0) wei[1] = w;
else if(x == 0 && y < 0) wei[3] = w;
else if(x > 0 && y == 0) wei[0] = w;
else if(x < 0 && y == 0) wei[2] = w;
else {
double k = y * 1.0 / x;
if(k > 0) {
p1.push_back(Point(x, y, w, k));
if(x > 0) xian1 += w;
else xian3 += w;
} else {
p2.push_back(Point(x, y, w, k));
if(x > 0) xian4 += w;
else xian2 += w;
}
}
}
ll ans = 0;
// 一、三象限
int up1 = xian1, down1 = 0, up3 = 0, down3 = xian3;
sort(p1.begin(), p1.end());
ans = max(ans, (wei[1] + wei[2] + xian2 + xian1) * (wei[0] + wei[3] + xian3 + xian4));
ans = max(ans, (wei[1] + wei[2] + xian2 + xian3) * (wei[0] + wei[3] + xian1 + xian4));
for(int i = 0; i < p1.size(); i++) {
if(p1[i].x > 0) { up1 -= p1[i].w; down1 += p1[i].w; }
else { down3 -= p1[i].w; up3 += p1[i].w; }
ans = max(ans, (wei[1] + wei[2] + xian2 + up1 + up3) * (wei[0] + wei[3] + xian4 + down1 + down3));
}
// 二、四象限
int up2 = 0, down2 = xian2, up4 = xian4, down4 = 0;
sort(p2.begin(), p2.end());
ans = max(ans, (wei[0] + wei[1] + xian1 + xian4) * (wei[2] + wei[3] + xian2 + xian3));
ans = max(ans, (wei[0] + wei[1] + xian1 + xian2) * (wei[2] + wei[3] + xian4 + xian3));
for(int i = 0; i < p2.size(); i++) {
if(p2[i].x > 0) { up4 -= p2[i].w; down4 += p2[i].w; }
else { down2 -= p2[i].w; up2 += p2[i].w; }
ans = max(ans, (wei[0] + wei[1] + xian1 + up2 + up4) * (wei[2] + wei[3] + xian3 + down2 + down4));
}
printf("%lld\n", ans);
}
return 0;
}

hdu6127的更多相关文章

  1. HDU6127 简单几何 暴力二分

    LINK 题意:给出n个点,每个点有个权值,可以和任意另外一点构成线段,值为权值积.现问过原点的直线中交所有线段的权值和的最大值,注意直线必不经过点. 思路:直线可以将点集分为两侧,此时的权值为两侧点 ...

  2. hdu6127 Hard challenge

    地址:http://acm.split.hdu.edu.cn/showproblem.php?pid=6127 题目: Hard challenge Time Limit: 4000/2000 MS ...

  3. 【极角排序】【扫描线】hdu6127 Hard challenge

    平面上n个点,每个点带权,任意两点间都有连线,连线的权值为两端点权值之积.没有两点连线过原点.让你画一条过原点直线,把平面分成两部分,使得直线穿过的连线的权值和最大. 就把点极角排序后,扫过去,一侧的 ...

  4. 2017 Multi-University Training Contest - Team 7

    HDU6121 Build a tree 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6121 题目意思:一棵 n 个点的完全 k 叉树,结点标号从 ...

随机推荐

  1. 理解NLP中的卷积神经网络(CNN)

    此篇文章是Denny Britz关于CNN在NLP中应用的理解,他本人也曾在Google Brain项目中参与多项关于NLP的项目. · 翻译不周到的地方请大家见谅. 阅读完本文大概需要7分钟左右的时 ...

  2. poj3375 Network Connection

    Description There are \(M\) network interfaces in the wall of aisle of library. And \(N\) computers ...

  3. 【Cf edu 30 B. Balanced Substring】

    time limit per test 1 second memory limit per test 256 megabytes input standard input output standar ...

  4. [COGS 2421] [HZOI 2016] 简单的Treap 笛卡尔树

    笛卡尔树就是你给两维限制,一维堆R,一维二叉搜索树K,平地拔起一棵Treap,最广范的应用:用LCA求区间最值,建Treap,还有个什么范围top k我表示并不会查都查不到.它最妙最高的地方在于用栈来 ...

  5. 设计一个JavaScript框架需要编写哪些模块

    在这个js框架随处乱跑的时代,你是否考虑过写一个自己的框架?下面的内容也许会有点帮助. 一个框架应该包含哪些内容? 1. 语言扩展 大部分现有的框架都提供了这部分内容,语言扩展应当是以ECMAScri ...

  6. HttpClientUntils工具类的使用测试及注意事项(包括我改进的工具类和Controller端的注意事项【附 Json 工具类】)

    HttpClient工具类(我改过): package com.taotao.httpclient; import java.io.IOException; import java.net.URI; ...

  7. HDU2732:Leapin' Lizards(最大流)

    Leapin' Lizards Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  8. Socket和ServerSocket学习笔记

    对于即时类应用或者即时类的游戏,HTTP协议很多时候无法满足于我们的需求.这会,Socket对于我们来说就非常实用了.下面是本次学习的笔记.主要分异常类型.交互原理.Socket.ServerSock ...

  9. jaspersoft中分组打印

    一:前言 使用IReport已经四个月了,最近在做一个保镖,是要按照类型分类,并且这些类型要横着打印,最后还要算这个类型金额的总值,这张报表现是说需要用到子报表,最后和一个同事一起用group来分组做 ...

  10. sql 批量更新表中多字段为不同的值

    ,),,),rand()) select newid() ,) update tablename , FB,)) , ), FC,)) , )