题目无法正常粘贴,地址:http://acm.hdu.edu.cn/showproblem.php?pid=5303

大意是给出一个环形公路,和它的长度,给出若干颗果树的位置以及树上的果子个数。

起点为0,背包大小为K,求最小走多少距离能摘完所有的果子并回到起点。

观察得知,公路长度L虽然上界10^9,但果子总和最多10^5,还是可做的。

显然如果想回家时在左半边肯定逆时针返回更近,在右边同理顺时针更近。

所有取果子的操作无非三种情况(顺时针出发逆时针返回&&逆时针出发顺时针返回&&顺时针一次走一圈<==>逆时针走一圈)。

*走整圈的情况==>最起码在装完左边的果子之后背包还有富余,不然没有往右走的必要,*而且在整个取果子过程中至多转一圈,否则只会比ans大。

由于背包的大小限制每次取果子的个数,为了方便处理数据,*我们不妨将果子做离散化处理,存进x数组中(x[i]即第i个果子的位置);

我们可以将左/右两边的果子按距离远点的距离排序放入两个l/r容器中。

之后dp1[i]表示从原点顺时针出发取得第i个果子再返回原点所需时间的一半(*保存为一半的距离方便计算),dp2同理.

处理完之后假设不饶圈,ans=dp1[l.size()]+dp2[r.size()];

接着我们枚举绕一圈的拿到的果子数即可,[0,K],而且不能超出左边的果子数,所以[0,min(K,l.size())];

对于此时,左边已经捡走了l.size()-i的果子到起点,右边就是r.size-(K-i),考虑到可能背包剩余空间大于右边的剩余果子,将其与0取较大者即可。

思考过程略复杂但代码量不多,值得多思考思考,精巧之处*号标注。

DP方程dp[i]={                  //i从1开始

l[i]                i<=k;

l[i]+dp[i-k]    i>k;

}

如果第i个果子大于k显然他要走到第i个果子的位置再返回,从路上带走k个果子,如果路上还有则继续返回带走,

在这个过程中如果想要路程最短化,根据贪心,他应该优先带走[1,i]中靠近处的果子,这样再次返回时走的更短。

#include<bits/stdc++.h>
#include<algorithm>
using namespace std;
#define LL long long
LL x[];
LL dp1[],dp2[];
vector<LL> l,r;
int main()
{
int N,M,K,L,T;
int i,j;
LL X,A;
scanf("%d",&T);
while(T--){int cnt=; LL ans;
l.clear(); r.clear();
scanf("%d %d %d",&L,&N,&K);
for(i=;i<N;++i){
scanf("%lld%lld",&X,&A);
for(j=;j<=A;++j)
x[++cnt]=(LL)X;
}
for(i=;i<=cnt;++i){
if(*x[i]<L) l.push_back(x[i]);
else r.push_back(L-x[i]);
}int szl=l.size(),szr=r.size();
sort(l.begin(),l.end());
sort(r.begin(),r.end());
for(i=;i<szl;++i){ dp1[i+]=(i+<=K?l[i]:dp1[i+-K]+l[i]);
}
for(i=;i<szr;++i){
dp2[i+]=(i+<=K?r[i]:dp2[i + -K]+r[i]);
}
ans=(dp1[szl]+dp2[szr])*;
for(i=1;i<=szl&&i<=K;++i){
int p1=szl-i;
int p2=max(,szr-(K-i));
ans=min(ans,*(dp1[p1]+dp2[p2])+L); }
printf("%lld\n",ans);
}
return ;
}

hdu 5303 DP(离散化,环形)+贪心的更多相关文章

  1. HDU 5303 Delicious Apples(贪心 + 背包 2015多校啊)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5303 Problem Description There are n apple trees plan ...

  2. 多校第二场 1004 hdu 5303 Delicious Apples(背包+贪心)

    题目链接: 点击打开链接 题目大意: 在一个周长为L的环上.给出n棵苹果树.苹果树的位置是xi,苹果树是ai,苹果商店在0位置,人的篮子最大容量为k,问最少做多远的距离可以把苹果都运到店里 题目分析: ...

  3. POJ3666 线性dp_离散化_贪心

    POJ3666 线性dp_离散化_贪心 就DP而言这个题不算难,但是难就难在贪心,还有离散化的思想上 题目大意:n个土堆,问你最少移动多少单位的图,可以使得这n个土堆变成单调的 dp[i][j]表示前 ...

  4. hdu 1677 Nested Dolls【贪心解嵌套娃娃问题】

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=1677 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  5. 【DP】+【贪心】【前缀和】洛谷P2893 [USACO08FEB]修路Making the Grade 题解

        正常的没想到的DP和玄学贪心. 题目描述 A straight dirt road connects two fields on FJ's farm, but it changes eleva ...

  6. POJ - 3666 Making the Grade(dp+离散化)

    Description A straight dirt road connects two fields on FJ's farm, but it changes elevation more tha ...

  7. hdu 3016 dp+线段树

    Man Down Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  8. CodeForces 55D "Beautiful numbers"(数位DP+离散化处理)

    传送门 参考资料: [1]:CodeForces 55D Beautiful numbers(数位dp&&离散化) 我的理解: 起初,我先定义一个三维数组 dp[ i ][ j ][ ...

  9. HDU 5928 DP 凸包graham

    给出点集,和不大于L长的绳子,问能包裹住的最多点数. 考虑每个点都作为左下角的起点跑一遍极角序求凸包,求的过程中用DP记录当前以j为当前末端为结束的的最小长度,其中一维作为背包的是凸包内侧点的数量.也 ...

随机推荐

  1. ping 10.13.5.233

    3. 环境 URL选择器 tableView ping 10.13.5.233

  2. Wireshark分析之TCP协议(二)

    (1)TCP首部格式 源端口:   用来传输数据报的端口 目标端口: 数据包将要发送到的端口 序号: 用来表示一个TCP片段.这个值用来表示数据流中的部分数据没有丢失 确认号:  表示通信中希望从另一 ...

  3. python基础之递归、二分法

    一 递归 1. 必须有一个明确的结束条件2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结 ...

  4. django的restfulapi

    Django Rest framework 的流程大概是这样的 建立 Models 依靠 Serialiers 将数据库取出的数据 Parse 为 API 的数据(可用于返回给客户端,也可用于浏览器显 ...

  5. display属性的表格布局相关属性

    基于CSS属性display:table的表格布局的使用   项目改造中遇到DIV+CSS实现的table,新需求需要在表格使用单元格合并,网上调查返现CSS display:table实现的tabl ...

  6. Ftp服务器配置讲解

    ftp.server.ip=192.168.80.130ftp.user=ftpuserftp.pass=ftpuserftp.server.http.prefix=http://image.imoo ...

  7. [RGEOS]空间拓扑关系

    -1.判断两个线段是否平行 inline bool parallel_seg_seg(Segment_2 S1, Segment_2 S2) { Vector_2 u(S1); Vector_2 v( ...

  8. zcash 的资料

    我的比特币使用的是 electrum 2.9.3 版本.我的zcash用的是 jaxx 1.2 版. zcash又叫zec,可以在 bithumb (韩国的) 平台上进行交易zcash. zcash ...

  9. 统计web日志里面一个时间段的get请求数量

    日志数据: ::::::: - - [/Nov/::: +] ::::::: - - [/Nov/::: +] ::::::: - - [/Nov/::: +] ``` **要求:按照时间每个小时统计 ...

  10. java基础语法 数组

    数组是相同数据类型元素的集合   数组本身是引用数据类型,即对象.但是数组可以存储基本数据类型,也可以存储引用数据类型. 在java中如果想要保存一组基本类型的数据,使用数组:如果想保存一组对象或者其 ...