http://acm.hdu.edu.cn/showproblem.php?pid=6365

细节处理

  • unique返回的是最后一位的后一位,因此从1开始的数组要减去(p+1)
  • 结构体可以用unqiue和lower_bound,因此结构体也可以离散化
  • 此处的斜率是x/y,因为这样定义斜率会随着x的增大而增大

思路

  • 一开始见到这道题,因为是个计算几何题,但是转换的思路十分巧妙:
  • 首先如何处理一条线段,假设我们穿过所有点的两个端点,一定可以穿过所有线段,所以每条线段转化为两个点
  • 那么如何处理每个点(x,y),因为假如斜率相同的点,都能被一条射线穿过,因此实际上衡量每个点的标准应该是他的斜率,因此将每个点转化为他的斜率
  • 根据斜率将点排序,以两点之间为区间进行区间dp,每次找区间内价值最大的一条线进行区间的分割,这样只有完全包含在枚举区间内的直线才能有贡献(即假如在穿过当前直线时同时穿过的其他直线永远也不会有贡献了)
  • 定义dp[i][j]为穿过包含在(i,j)区间所有直线所需要的最小代价(即穿过(i,j)区间但并不在i,j区间内的直线可能会被穿过,但是贡献在之前已经被计算了)

    转移方程为

dp[i][j]=min(dp[i][j],dp[i][k-1]+dp[k+1][j]+w[k]);

#include<bits/stdc++.h>
#define M 305
#define ll long long
#define inf 1e16
using namespace std;
int n,i,T,sz;
ll h[M<<1],w[M<<1],l[M<<1],r[M<<1],dp[M<<1][M<<1]; struct N{
ll x,y;
N(){}
N(ll x,ll y): x(x),y(y){}
bool operator ==(const N& rhp)const{
return x*rhp.y-y*rhp.x==0;
}
bool operator<(const N& rhp)const{
return x*rhp.y-y*rhp.x<0;
}
}p[M<<1];
int id(N a){ return lower_bound(p+1,p+1+sz,a)-p;} ll dfs(int L,int R){
ll &ans=dp[L][R];
if(L>R)return 0;
if(ans!=-1)return ans;
ans=0;
ll ma=-1,x;
for(int i=1;i<=n;i++){
if(L<=l[i]&&r[i]<=R){
if(w[i]>ma){
ma=w[i];x=i;
}
}
}
if(ma==-1)return ans;
ans=inf;
for(int i=l[x];i<=r[x];i++){
ans=min(ans,dfs(L,i-1)+dfs(i+1,R)+ma);
}
return ans;
}
int main(){
scanf("%d",&T);
while(T--){
memset(dp,-1,sizeof(dp));
scanf("%d",&n);
for(i=1;i<=n;i++){
scanf("%lld%lld%lld%lld",&h[i],&l[i],&r[i],&w[i]);
p[2*i-1]=N(l[i],h[i]);
p[2*i]=N(r[i],h[i]);
}
sort(p+1,p+1+2*n);
sz=unique(p+1,p+2*n+1)-p-1;
for(i=1;i<=n;i++){
l[i]=id(N(l[i],h[i]));
r[i]=id(N(r[i],h[i]));
}
printf("%lld\n",dfs(1,sz));
}
}

hdu6365 2018 Multi-University Training Contest 6 1004 Shoot Game的更多相关文章

  1. hdu 6301 Distinct Values (2018 Multi-University Training Contest 1 1004)

    Distinct Values Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  2. HDU 6312.Game-博弈-签到题 (2018 Multi-University Training Contest 2 1004)

    2018 Multi-University Training Contest 2 6312.Game 博弈,直接官方题解,懒了. 考虑将游戏变成初始时只有2~n,如果先手必胜的话,那么先手第一步按这样 ...

  3. HDU 6335.Problem D. Nothing is Impossible-思维题 (2018 Multi-University Training Contest 4 1004)

    6335.Problem D. Nothing is Impossible 题意:给你n道题目,m个人,每题有x个正确选项,y个错误选项,问你做对题数量最多的人做对了多少道题目. 如果一道题有y个错误 ...

  4. HDU 6322.Problem D. Euler Function -欧拉函数水题(假的数论题 ̄▽ ̄) (2018 Multi-University Training Contest 3 1004)

    6322.Problem D. Euler Function 题意就是找欧拉函数为合数的第n个数是什么. 欧拉函数从1到50打个表,发现规律,然后勇敢的水一下就过了. 官方题解: 代码: //1004 ...

  5. HDU 6301.Distinct Values-贪心、构造字典序最小的数列 (2018 Multi-University Training Contest 1 1004)

    HDU6301.Distinct Values 这个题就是给你区间要求区间内的数都不相同,然后要求是字典序最小,直接贪心走一遍,但是自己写的时候,思路没有错,初始化写挫了... 将区间按左端点小的排序 ...

  6. 2018 Nowcoder Multi-University Training Contest 2

    目录 Contest Info Solutions A. run D. monrey G. transform H. travel I. car J. farm Contest Info Practi ...

  7. dp - 2015 Multi-University Training Contest 2 1004 Delicious Apples

    Delicious Apples Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=5303 Mean: 一条长为L的环形路上种着n棵 ...

  8. 2015 Multi-University Training Contest 2 1004 Delicious Apples(DP)

    pid=5303">题目链接 题意:长度为l 的环,有n棵果树,背包容量为k,告诉你k棵苹果树的id.以及每棵树上结的果子数.背包一旦装满要返回起点(id==0) 清空,问你至少走多少 ...

  9. 2018 Nowcoder Multi-University Training Contest 1

    Practice Link J. Different Integers 题意: 给出\(n\)个数,每次询问\((l_i, r_i)\),表示\(a_1, \cdots, a_i, a_j, \cdo ...

随机推荐

  1. linux同步机制2

    一.并发控制(1)自旋锁得不到资源,会原地打转,直到获得资源为止定义自旋锁 spinlock_t spin;初始化自旋锁 spin_lock_init(lock);获得自旋锁spin_lock(loc ...

  2. 使用python读写CSV文件

    # -*- coding:UTF-8 -*- __autor__ = 'zhouli' __date__ = '2018/10/25 21:14' import csv with open('resu ...

  3. Linux系统下重启Tomcat

    在Linux系统下,重启Tomcat使用命令操作的! 首先,进入Tomcat下的bin目录 cd /usr/local/tomcat/bin 使用Tomcat关闭命令 ./shutdown.sh 查看 ...

  4. linux-ubuntu 安装配置Redis

    >wget http://download.redis.io/releases/redis-3.2.6.tar.gz #下载redis源码包 >tar -zxvf redis-3.2.6. ...

  5. 6-完美解决Error:SSL peer shut down incorrectly

    转载自: 完美解决Error:SSL peer shut down incorrectly 打开gradle文件夹下的gradle-wrapper文件 修改其中的配置文件将红色区域修改为http:// ...

  6. ret和retf

    ret指令用栈中的数据,修改IP的内容,从而实现近转移; retf指令用栈中的数据,修改CS和IP的内容,从而实现远转移. CPU执行ret指令时,进行下面两步操作: (IP) = ((ss)*16+ ...

  7. SideBar 选择城市时右侧边上的 选择bar

    需要定义一个SideBar的视图类  在布局文件中引用   同时在布局中设置一个textView默认不可见 当触摸时才显示   在调用的Activity中 sideBar.setOnTouchingL ...

  8. Could not load file or assembly 'Microsoft.EntityFrameworkCore.Relational

    提示的很明确了,缺少Microsoft.EntityFrameworkCore.Relational引用.nuget安装上即可.

  9. IDEA配置maven,jdk,编码

    1.电脑已解压maven,修改好settings.xml文件,本地仓库,下载远程镜像 2.

  10. InstallShield 2015 安装 在vs2015

     网上很少注册InstallShield 2015  的方法,而且很多以前版本的注册也很笼统,今天我就说说几个细节上的问题.相信大家看了会有帮助,有问题回帖,我会及时跟上, 先说说我遇到的问题 安装: ...