题目链接:Oil

  感觉同时几线作战有点吃不消啊……

  这道题有一个显然的结论,那就是最优的直线一定过某条线段的端点。

  仔细想想很有道理。如果最终的直线没有过线段的端点的话,那么这条直线就一定可以平移,直到过端点为止。

  于是我们可以枚举直线上的一个点,由于直线不能与线段平行,那么与枚举的点纵坐标不同的线段就对应着一个斜率区间。于是这个问题就转化成了一个经典问题:有$n$个区间,第$i$个区间$[l_i,r_i]$会给区间内的所有位置(可以不是整数)加上一个权值$c_i$,求最后所有位置中最大的权值。这个问题解法很简单,就是把每个区间拆成两个点,然后从左往右扫,扫到左端点就加上权值,扫到右端点就减去权值,取个$\max$即可。

  还有一点小优化:枚举点的时候不必枚举所有端点,可以只枚举所有左端点(或者右端点)。因为如果最终的直线不过任何线段的左端点的话,那么一定可往左平移到过一个左端点为止。

  还有计算斜率的时候由于可能会有斜率不存在的情况,可以把斜率式中的$x$、$y$互换一下,方便计算。

  下面贴代码(自带巨大常数):

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define File(s) freopen(s".in","r",stdin),freopen(s".out","w",stdout)
#define N 2010
#define eps (1e-8) using namespace std;
typedef double llg; struct data{
int x,y;
}l[N],r[N],a[N];
struct dato{
llg l,r;int c;
}s[N],sl[N],sr[N];
int n,ans,ls,ld;
llg d[N<<1]; bool cmpl(dato a,dato b){return a.l<b.l;}
bool cmpr(dato a,dato b){return a.r<b.r;} int main(){
File("a");
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d %d %d",&l[i].x,&r[i].x,&r[i].y); l[i].y=r[i].y;
if(l[i].x>r[i].x) swap(l[i],r[i]); a[i]=l[i];
d[++ld]=l[i].x,d[++ld]=r[i].x;
ans=max(ans,r[i].x-l[i].x);
}
for(int i=1,id,now;i<=n;i++){
ls=ld=0; id=(i-1)%n+1;
for(int j=1;j<=n;j++)
if(l[j].y!=a[i].y){
ls++; s[ls].c=r[j].x-l[j].x;
s[ls].l=(llg)(l[j].x-a[i].x)/(llg)(l[j].y-a[i].y);
s[ls].r=(llg)(r[j].x-a[i].x)/(llg)(r[j].y-a[i].y);
if(s[ls].l>s[ls].r) swap(s[ls].l,s[ls].r);
}
if(ls){
now=r[id].x-l[id].x;
for(int i=1;i<=ls;i++) d[++ld]=s[i].l,d[++ld]=s[i].r,sl[i]=sr[i]=s[i];
sort(d+1,d+ld+1); ld=unique(d+1,d+ld+1)-d-1;
sort(sl+1,sl+ls+1,cmpl); sort(sr+1,sr+ls+1,cmpr);
for(int i=1,zl=1,zr=1;i<=ld;i++){
while(zl<=ls && d[i]==sl[zl].l) now+=sl[zl++].c;
ans=max(ans,now);
while(zr<=ls && d[i]==sr[zr].r) now-=sr[zr++].c;
}
}
}
printf("%d",ans);
return 0;
}

BZOJ 4614 【Wf2016】 Oil的更多相关文章

  1. BZOJ 1854 【Scoi2010】 游戏

    Description lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的某一个属性 ...

  2. BZOJ 1303 【CQOI2009】中位数图

    baidu了一下bzoj水题列表...找到这道题.   题目大意:给定一个数t,在给定的一段包含1-n的序列中找出多少个长度为奇数子序列的中位数为t. 第一眼没看数据范围,于是开心的打了一个O(n^3 ...

  3. 【BZOJ】【1177】【APIO2009】Oil

    DP 找出三个正方形,可以转化为将整个油田切成三个矩形块,每块中各找一个正方形区域,切的形式只有6种,分类更新ans即可 题解:http://trinklee.blog.163.com/blog/st ...

  4. BZOJ 1853 【Scoi2010】 幸运数字

    Description 在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认 为,于是他定义自己的"幸运号码"是十进制表示中只包含数字6和8的那些号码,比如68,666,8 ...

  5. BZOJ 1026 【SCOI2009】 windy数

    Description windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之间,包括A和B,总共有多少个windy数? I ...

  6. BZOJ 3669 【NOI2014】 魔法森林

    Description 为了得到书法大家的真传,小E同学下定决心去拜访住在魔法森林中的隐士.魔法森林可以被看成一个包含个N节点M条边的无向图,节点标号为1..N,边标号为1..M.初始时小E同学在号节 ...

  7. UOJ#58/BZOJ 3052【WC2013】糖果公园

    好写好调的莫队算法,就算上树了仍然好写好调. 传送门 http://uoj.ac/problem/58 简要做法 将树按照dfs序分块,然后将询问按照(u所在块,v所在块,时间)作为关键字进行排序,依 ...

  8. 洛谷 P2634 BZOJ 2152 【模板】点分治(聪聪可可)

    题目描述 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好了,可是他们已 ...

  9. BZOJ 1096 【ZJOI2007】 仓库建设

    Description L公司有N个工厂,由高到底分布在一座山上.如图所示,工厂1在山顶,工厂N在山脚.由于这座山处于高原内陆地区(干燥少雨),L公司一般把产品直接堆放在露天,以节省费用.突然有一天, ...

随机推荐

  1. PHP的学习--在Atom中使用XDebug(Mac)

    之前写过一篇博客<PHP的学习--在sublime中使用XDebug(Ubuntu)>,讲了在Ubuntu系统 sublime 中配置 XDebug,其实配置好之后,我也很少用,原因有两点 ...

  2. 基於tiny4412的Linux內核移植--- 中斷和GPIO學習(3)

    作者 彭東林 pengdonglin137@163.com 平臺 tiny4412 ADK Linux-4.4.4 u-boot使用的U-Boot 2010.12,是友善自帶的,爲支持設備樹和uIma ...

  3. 5.C#WinForm基础登陆失败三次退出系统

    目标: 登陆界面,登陆错误三次退出程序.假设用户名密码是admin.888888,不区分大小写,(易错点:局部变量与类变量) 局部变量每次运行完毕变量的值都会被销毁,下次再运行,会重新初始化.     ...

  4. javaWeb应用打包

    在Java中,使用"jar"命令来对将JavaWeb应用打包成一个War包,jar命令的用法如下:

  5. Angular 基础入门

    简介 什么是AngularJS 一个功能非常完备的前端框架,通过增强HTML的方式提供一种便捷开发Web应用程序的方式 其核心特点就是几乎无任何DOM操作,让开发人员的精力和时间全部集中于业务 MVC ...

  6. 仅此一文让你明白ASP.NET MVC原理

    ASP.NET MVC由以下两个核心组成部分构成: 一个名为UrlRoutingModule的自定义HttpModule,用来解析Controller与Action名称: 一个名为MvcHandler ...

  7. 翻译:使用 ASP.NET MVC 4, EF, Knockoutjs and Bootstrap 设计和开发站点 - 4 - 验证

    验证: 快要完成我们程序的界面部分了.剩下的事情就是在用户点击 "保存" 的时候管理验证问题了.验证是主要需求,今天就是最无知的应用也不会忽视它.通过正确的验证,用户可以知道应该输 ...

  8. shiro的使用1 简单的认证

    最近在重构,有空学了一个简单的安全框架shiro,资料比较少,在百度和google上能搜到的中文我看过了,剩下的时间有空会研究下官网的文章和查看下源码, 简单的分享一些学习过程: 1,简单的一些概念上 ...

  9. 通过Java代码实现对数据库的数据进行操作:增删改查

    在写代码之前,依然是引用mysql数据库的jar包文件:右键项目-构建路径-设置构建路径-库-添加外部JAR 在数据库中我们已经建立好一个表xs :分别有xuehao  xingming    xue ...

  10. 记录一次bug解决过程:eclipse Installed JREs 配置引出的问题

    一 总结 eclipse Installed JREs 配置引出的问题:编译以来JDK,不是JRE spring boot内嵌tomcat运行程序,tomcat:run 二 Bug描述:eclipse ...