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. What is state and props

    State, in React component, is internal dataset which affects the rendering of the component. To some ...

  2. 制作framework&静态库

    http://blog.csdn.net/justinjing0612/article/details/7880712     (制作framework) http://blog.sina.com.c ...

  3. 笔试算法题(18):常数时间删除节点 & 找到仅出现一次的两个数字

    出题:给定链表的头指针和一个节点指针,要求在O(1)的时间复杂度下删除该节点 分析: 如果需要删除的节点为A,其前序节点为A-,其后续节点为A+,所以删除A之后,需要使得A-的下一个节点就是A+,常规 ...

  4. [Python3网络爬虫开发实战] 1.3.2-Beautiful Soup的安装

    Beautiful Soup是Python的一个HTML或XML的解析库,我们可以用它来方便地从网页中提取数据.它拥有强大的API和多样的解析方式,本节就来了解下它的安装方式. 1. 相关链接 官方文 ...

  5. awk,grep,sed文本格式化处理

    一.awk取列 [root@web01 ~]# cat /etc/passwd|awk -F ':' '{print $1"\t\t"$7}' ###-F指定分隔符 root /b ...

  6. 一个页面从输入URL到加载显示完成,发生了什么?

    面试经典题--URL加载 一.涉及基本知识点: 1. 计算机网络 五层因特尔协议栈: 应用层(dns.http):DNS解析成IP并完成http请求发送: 传输层(tcp.udp):三次握手四次挥手模 ...

  7. Django之初

    Django之初 Django的开始: #安装Django: pip3 install django #创建Django项目: django-admin startproject 项目名 #比如: d ...

  8. First C program

    come from https://mooc.study.163.com/learn/1000002011?tid=2001530003#/learn/content?type=detail& ...

  9. loadrunner-3个难点

    1.loadrunner 监控windows资源 2.loadrunner如何实现如下: 1.1.1.1 场景一 10进程同时新增用户 测试场景说明:10进程新增用户, 第一个进程从1到1000,第二 ...

  10. Web框架django基础篇

    基本配置及学习  路由(Urls).视图(Views).模板(Template).Model(ORM). 简介 Django 是一个由 Python 写成的开放源代码的 Web 应用框架.它最初是被开 ...