P1759 通天之潜水

    • 19通过
    • 65提交
  • 题目提供者lych
  • 标签动态规划洛谷原创
  • 难度普及/提高-

提交该题 讨论 题解 记录

最新讨论

  • 暂时没有讨论

题目背景

直达通天路·小A历险记第三篇

题目描述

在猴王的帮助下,小A终于走出了这篇荒山,却发现一条波涛汹涌的河拦在了自己的面前。河面上并没有船,但好在小A有n个潜水工具。由于他还要背重重的背包,所以他只能背m重的工具,又因为他的力气并不是无限的,河却很宽,所以他只能背有v阻力的工具。但是这条河下有非常重要的数据,所以他希望能够停留的时间最久。于是他找到了你,让你告诉他方案。

输入输出格式

输入格式:

三个数m,v,n如题目所说

接下来n行,每行三个数ai,bi,ci分别表示所含的重力,阻力,能够支撑的时间

输出格式:

第一行一个数,表示最长的时间

接下来一行,若干个数,表示所选的物品

输入输出样例

输入样例#1:

100 100 3
50 60 289
40 10 116
50 50 106
输出样例#1:

405
1 2

说明

1<=m,v<=200,n<=100

数据保证一定有方案。

若有多种方案,输出前面尽量小的方案。

60分代码:

#include<cstdio>
#include<iostream>
using namespace std;
#define N 1001
int n,m,q,ans[N];
int v[N],g[N],c[N];
int f[N][N];
int main(){
scanf("%d%d%d",&n,&m,&q);
for(int i=;i<=q;i++) scanf("%d%d%d",&v[i],&g[i],&c[i]);
for(int i=;i<=q;i++){
for(int j=v[i];j<=n;j++){
for(int k=g[i];k<=m;k++){
int tmp=f[j-v[i]][k-g[i]]+c[i];
if(j==n&&k==m){
if(tmp>f[j][k]) f[j][k]=tmp,ans[++ans[]]=i;
else if(tmp==f[j][k]&&(n>v[i]||m>g[i])) ans[++ans[]]=i;
}
else if(tmp>f[j][k]) f[j][k]=tmp;
}
}
}
printf("%d\n",f[n][m]);
for(int i=;i<=ans[];i++) printf("%d ",ans[i]);
return ;
}

题解:

”最长的时间“的dp转移

f[j][k]=Max(f[j][k],f[j-v[i]][k-g[i]]+c[i]);

f[j][k]表示在j重力k阻力的情况下的最长时间

难点在于输出所选的物品

这样,维护一个len,记录选了几个物品;

维护一个a[],记录当期所选物品的编号:每一次更新答案,把上一次的所选物品复制过来,再加上当前物品。

AC代码:

#include<cstdio>
#include<iostream>
using namespace std;
#define N 201
int n,m,q,ans[N];
int v[N],g[N],c[N];
struct node{
int w,len;
int a[];
} f[N][N];
int main(){
scanf("%d%d%d",&n,&m,&q);
for(int i=;i<=q;i++) scanf("%d%d%d",&v[i],&g[i],&c[i]);
for(int i=;i<=q;i++){
for(int j=n;j>=v[i];j--){
for(int k=m;k>=g[i];k--){
if(f[j][k].w<f[j-v[i]][k-g[i]].w+c[i]){
f[j][k].w=f[j-v[i]][k-g[i]].w+c[i];
for(int t=;t<=f[j][k].len;t++) f[j][k].a[t]=f[j-v[i]][k-g[i]].a[t];
f[j][k].len=f[j-v[i]][k-g[i]].len+;
f[j][k].a[f[j][k].len]=i;
}
}
}
}
printf("%d\n",f[n][m].w);
for(int i=;i<=f[n][m].len;i++) printf("%d ",f[n][m].a[i]);
return ;
}

洛谷 P1759 通天之潜水的更多相关文章

  1. 洛谷——P1759 通天之潜水

    P1759 通天之潜水   题目背景 直达通天路·小A历险记第三篇 题目描述 在猴王的帮助下,小A终于走出了这篇荒山,却发现一条波涛汹涌的河拦在了自己的面前.河面上并没有船,但好在小A有n个潜水工具. ...

  2. 洛谷P1759 通天之潜水

    题目背景 直达通天路·小A历险记第三篇 题目描述 在猴王的帮助下,小A终于走出了这篇荒山,却发现一条波涛汹涌的河拦在了自己的面前.河面上并没有船,但好在小A有n个潜水工具.由于他还要背重重的背包,所以 ...

  3. P1759 通天之潜水(双写法+解析)

    算法解析 动态规划问题满足三大重要性质 最优子结构性质:如果问题的最优解所包含的子问题的解也是最优的,我们就称该问题具有最优子结构性质(即满足最优化原理).最优子结构性质为动态规划算法解决问题提供了重 ...

  4. P1759 通天之潜水(不详细,勿看)(动态规划递推,组合背包,洛谷)

    题目链接:点击进入 题目分析: 简单的组合背包模板题,但是递推的同时要刷新这种情况使用了哪些物品 ac代码: #include<bits/stdc++.h> using namespace ...

  5. luogu P1759 通天之潜水

    题目背景 直达通天路·小A历险记第三篇 题目描述 在猴王的帮助下,小A终于走出了这篇荒山,却发现一条波涛汹涌的河拦在了自己的面前.河面上并没有船,但好在小A有n个潜水工具.由于他还要背重重的背包,所以 ...

  6. 洛谷P1757 通天之分组背包

    题目背景 直达通天路·小A历险记第二篇 题目描述 自01背包问世之后,小A对此深感兴趣.一天,小A去远游,却发现他的背包不同于01背包,他的物品大致可分为k组,每组中的物品相互冲突,现在,他想知道最大 ...

  7. 洛谷——P1757 通天之分组背包

    P1757 通天之分组背包 题目背景 直达通天路·小A历险记第二篇 题目描述 自01背包问世之后,小A对此深感兴趣.一天,小A去远游,却发现他的背包不同于01背包,他的物品大致可分为k组,每组中的物品 ...

  8. 洛谷 P1757 通天之分组背包

    P1757 通天之分组背包 题目背景 直达通天路·小A历险记第二篇 题目描述 自01背包问世之后,小A对此深感兴趣.一天,小A去远游,却发现他的背包不同于01背包,他的物品大致可分为k组,每组中的物品 ...

  9. 洛谷 P1760 通天之汉诺塔

    P1760 通天之汉诺塔 题目背景 直达通天路·小A历险记第四篇 题目描述 在你的帮助下,小A成功收集到了宝贵的数据,他终于来到了传说中连接通天路的通天山.但是这距离通天路仍然有一段距离,但是小A突然 ...

随机推荐

  1. css + 和 ~的区别

    <style type="text/css"> h1 + p { margin-top:50px; color:red; } </style> <p& ...

  2. Android图像处理之Bitmap类(1)

    Bitmap是Android系统中的图像处理的最重要类之一.用它可以获取图像文件信息,进行图像剪切.旋转.缩放等操作,并可以指定格式保存图像文件.本文从应用的角度,着重介绍怎么用Bitmap来实现这些 ...

  3. 关于动态添加的html元素绑定的事件不生效的解决办法

    1.可以通过行内添加事件的方法,比如onclick="fn()"; 在js中写好方法名对应的方法就可以了,如果绑定方法的元素太多 2.jquery的on事件绑定 //on事件可以给 ...

  4. python爬取网页图片

    # html:网页地址 def getImg2(html): soup = BeautifulSoup(html, 'html.parser') href_regex = re.compile(r'^ ...

  5. GNU编译器学习 --> 如何链接外部库【Linking with external libraries】

    库也就是我们常说的library,一个库是若干个已经编译过的目标文件(.obj)的集合,它可以被链接到程序里.那么我们最常见的使用就是,我们在编程时会调用一些函数,这些函数别人已经写好了,它就放在库里 ...

  6. idea搭建SSM的maven项目(tomcat容器)

    一.创建maven的web项目 (1)选择项目的骨架 (2)写项目的坐标 (3)maven的设置 设置maven的本地仓库,以及配置文件的位置,同时点击+号,填入archetypeCatalog和in ...

  7. python3爬虫-爬取58同城上所有城市的租房信息

    from fake_useragent import UserAgent from lxml import etree import requests, os import time, re, dat ...

  8. python爬虫框架—Scrapy安装及创建项目

    linux版本安装 pip3 install scrapy 安装完成 windows版本安装 pip install wheel 下载twisted,网址:http://www.lfd.uci.edu ...

  9. 用java实现二分搜索<算法分析>

    实验目的:1.复习java编程:2.掌握二分搜索技术的基本原理:3.掌握使用java程序进行二分搜索的方法.实验步骤:1.由用户输入5个以上的整数:2.利用二分搜索算法完成对数组的搜索. packag ...

  10. noip模拟赛 分组

    分析:暴力分挺多,也挺好想的,个人感觉两个特殊性质没什么卵用. 对于K=1,n ≤ 1024的情况,从后往前贪心地分,如果能和上一组分在一起就分在一起,否则就再开一组,这样可以保证字典序最小.ai ≤ ...