【动态规划】叠放箱子问题(ssl 1640)

叠放箱子问题叠放箱子问题

Description

某港口有一批集装箱,将其编号,分别为1至N。每一个箱子的外型尺寸都是一样的,现在要将其中某些集装箱叠放起来,集装箱叠放的规则如下:

1)每个集装箱上最多只能直接叠放一个集装箱。

2)编号较小的集装箱不能放在编号较大的集装箱之上。

3)每个集装箱都给出了自身的重量和可承受的重量,每个集装箱之上的所有集装箱重量之和不得超过该集装箱的可承受的重量。

现在要求你编程,从中选出最多个集装箱,使之在满足以上条件的情况下叠放起来,即要求叠得尽可能地高。

Input

第一行是一个正整数N,表示共有N个集装箱(1≤ N ≤1000)。

以下共有N行,每行两个正整数,中间用空格分隔,分别表示每个集装箱的自身重量和可承受的重量,两个数均为小于等于3000。

Output

输出最多可叠放的集装箱总数。运行时间不超过去时10秒。

Sample Input

5

19 15

7 13

5 7

6 8

1 2

Sample Output

题目大意:

有n个箱子,每个箱子都有自己的编号,自身重量,可承受重量(输入第i+1行是编号为i的箱子自身重量和可承受重量),编号小的必须在编号大的下面,箱子上面只能直接放一个箱子,但上面的这个箱子上面还可以放箱子(例如下图是合法的),求最多可叠放多少个箱子

在这里插入图片描述


方法一方法一

用一个二维数组f[i][j]来表示第i个箱子到第n个箱子重量为j时箱子的最大数,然后从上往下从后往前一次推过来,最后再从f[1][i](i=0~6000)中选一个最大的即可

动态转移方程

f[i][j]=max{f[i+1][j]notselectif((j>=v[i])and(c[i]>=j−v[i]))f[i+1][j−v[i]]+1selectf[i][j]=max\left\{\begin{matrix} f[i+1][j]&&not select \\ if ((j>=v[i])and(c[i]>=j-v[i]))&f[i+1][j-v[i]]+1&select \end{matrix}\right.f[i][j]=max{f[i+1][j]if((j>=v[i])and(c[i]>=jv[i]))f[i+1][jv[i]]+1notselectselect

说明:

v为自身重量,c为可承受重量

#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int n,ans,v[1002],c[1002],f[1002][6002];
int main()
{scanf("%d",&n);for (int i=1;i<=n;i++)scanf("%d%d",&v[i],&c[i]);memset(f,-127/3,sizeof(f));//初值f[n+1][0]=0;//初值for (int i=n;i>0;i--)for (int j=0;j<=6000;j++){f[i][j]=f[i+1][j];//不放if ((j>=v[i])&&(c[i]>=j-v[i]))//j>=v[i]是为了保证j-v[i]不为负数,c[i]>=j-v[i]是为了保证他可以承受上面的重量f[i][j]=max(f[i][j],f[i+1][j-v[i]]+1);//状态转移方程}for (int i=0;i<=6000;i++)ans=max(ans,f[1][i]);//取最大值printf("%d",ans);return 0;
}

方法二方法二

用f[i][j]来表示上面的i个箱子选j个箱子的最小值,然后每一层如果不放就直接等于上面的,如果放就要判断是否能承受上方箱子的重量,再加上当前重量去最小值

动态转移方程:

f[i][j]=min{f[i+1][j]notselectif(f[i+1][j−1]&lt;=c[i])f[i+1][j−1]+v[i]selectf[i][j]=min\left\{\begin{matrix} f[i+1][j]&amp;&amp;not select \\ if (f[i+1][j-1]&lt;=c[i])&amp;f[i+1][j-1]+v[i]&amp;select \end{matrix}\right.f[i][j]=min{f[i+1][j]if(f[i+1][j1]<=c[i])f[i+1][j1]+v[i]notselectselect

#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int n,v[1005],c[1005],f[1005][1005],u;
int main()
{scanf("%d",&n);for (int i=1;i<=n;++i)scanf("%d%d",&v[i],&c[i]);for(int i=1;i<=n;++i)for(int j=1;j<=n;++j)f[i][j]=2147483647/3;//初始化u=2147483647/3;f[n][1]=v[n];//初值for (int i=n-1;i>0;--i)//枚举第i个箱子for (int j=1;j<=n-i+1;++j)//枚举重量{f[i][j]=f[i+1][j];//不放就继承上一个的最小重量if (f[i+1][j-1]<=c[i])//判断是否能承受f[i][j]=min(f[i][j],f[i+1][j-1]+v[i]);//动态转移方程}for (int i=n;i>=0;--i)if (f[1][i]!=u)//若有变化及可输出{printf("%d",i);break;//退出,避免重复输出}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321426.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu 16.04+.Net Core+Docker+Nginx安装部署

前言最近公司的项目打算移植到.Net Core平台&#xff0c;所以调研了一下.Net Core在Linux下的安装部署。本篇文章会一步步的描述从安装到配置到部署的全部过程。在文章的结构和内容里&#xff0c;笔者借鉴了很多其他博文的内容&#xff0c;但感觉其他博文中都只是实现了一部分或…

玩Docker只要浏览器就够了,PWD是个神奇的网站

本文是d4d系列的第9篇&#xff0c;在这一篇中给大家介绍一个学习Docker最为快捷高效的方式&#xff0c;你不需要自己搭建环境&#xff0c;也不用担心把自己的开发环境搞乱&#xff0c;你需要的只是一个浏览器&#xff0c;就可以立即开始学习Docker的常用命令&#xff1b;你甚至…

[系统安全]使用OD编写连连看外挂

文档下载地址&#xff1a;https://pan.baidu.com/s/1hrzzerq

2018 .NET开发者调查报告: .NET Core 是怎么样的状态

4月28日&#xff0c;在公众号里发起《.NET Core 使用调查》&#xff0c;该调查为期一周&#xff0c;有近3300名开发者参与&#xff0c;统计下结果供你的决策参考。已经使用.net core 的人数只有44%&#xff0c;计划使用.net core 比例达到48%&#xff0c; 没有计划去使用.net …

软件质量保证划重点期末复习总结

软件质量保证复习总结大纲及问题 Module1 《软件工程实践》 1、软件工程实践通过解决问题的根源来指导软件开发。 2、软件工程实践之间相辅相成。 3、过程指导一个团队在什么时候做什么以及如何做。 4、软件工程过程为实现软件工程实践提供了上下文和支持。 Module2 《软件…

Microsoft Build 2018 直播来啦!

一年一度的Microsoft Build大会又来啦&#xff01;Microsoft Build是微软面向全球开发者、合作伙伴以及消费者介绍其重要产品在未来一年内发展方向的技术盛会。而今年的Microsoft Build 2018大会是微软巨大蜕变、最彻底组织变革后的第一次前沿技术大会。更多了解&#xff0c;请…

【动态规划】矩阵链相乘 (ssl 1596)/能量项链 (ssl 2006)

矩阵链相乘{\color{Cyan} 矩阵链相乘 }矩阵链相乘 Description Input n表示矩阵的个数(<100) n1个数,表示矩阵(<100) Output 最小的乘法次数 Sample Input 5 5 10 4 6 10 2 Sample Output 348 题目大意&#xff1a; 有n个矩阵&#xff0c;输入n1个数&#x…

10、mybatis中缓存的使用

对于初学者&#xff0c;如何进行mybatis的学习呢&#xff1f;我总结了几点&#xff0c;会慢慢的更新出来。首先大家需要了解mybatis是什么、用mybatis来做什么、为什么要用mybatis、有什么优缺点&#xff1b;当知道了为什么的时候就开始了解如何用的问题&#xff0c;如何使用my…

C#编译器优化那点事

使用C#编写程序&#xff0c;给最终用户的程序&#xff0c;是需要使用release配置的&#xff0c;而release配置和debug配置&#xff0c;有一个关键区别&#xff0c;就是release的编译器优化默认是启用的。优化代码开关即optimize开关&#xff0c;和debug开关一起&#xff0c;有以…

如何在Visual Studio 2017中使用C# 7+语法

前言之前不知看过哪位前辈的博文有点印象C# 7控制台开始支持执行异步方法&#xff0c;然后闲来无事&#xff0c;搞着&#xff0c;搞着没搞出来&#xff0c;然后就写了这篇博文&#xff0c;不喜勿喷&#xff0c;或许对您有帮助。在Visual Studio 2017配置支持C# 7语法心想都VS20…

11、mybatis的功能架构分析

1、Mybatis功能架构 1&#xff09;API接口层&#xff1a;提供给外部使用的接口API&#xff0c;开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。 2&#xff09;数据处理层&#xff1a;负责具体的SQL查找、SQL解析、SQL执…

【动态规划】方格取数 (ssl 1010)

方格取数方格取数方格取数 Description 设有N*N的方格图(N<10,我们将其中的某些方格中填入正整数,而其他的方格中则放入数字0。如下图所示&#xff08;见样例&#xff09;&#xff1a; 某人从图的左上角的A 点出发&#xff0c;可以向下行走&#xff0c;也可以向右走&#…

ASP.NET Core 使用UrlFirewall对请求进行过滤

一. 前言UrlFirewall 是一个开源、轻便的对http请求进行过滤的中间件&#xff0c;可使用在webapi或者网关&#xff08;比如Ocelot&#xff09;,由我本人编写&#xff0c;并且开源在github&#xff1a;https://github.com/stulzq/UrlFirewall 欢迎star.二.UrlFirewall 介绍UrlFi…

1、设计模式和原则总述

目录 一、什么是设计模式&#xff1f;有什么用&#xff1f; 二、设计模式 三、设计原则 一、什么是设计模式&#xff1f;有什么用&#xff1f; 设计模式是一套代码设计的经验总结&#xff0c;使用设计模式可以提高代码的重用性、可靠性&#xff0c;提交代码内聚&#xff0c;降…

Visual Studio 15.7预览版4改进Git、C++支持

对于即将到来的Visual Studio 2017 15.7&#xff0c;微软已经发布了多个新的预览版本。这些版本的变更很有限&#xff0c;似乎离正式发布不远了。通常&#xff0c;变更的涉及面很广——因此&#xff0c;不管是用什么语言&#xff0c;开发人员都可以看到一些好处。第一次&#x…

P2827-蚯蚓【队列】

前言 早年一直拿堆过不了&#xff0c;结果发现要用队列 正题 题目链接:https://www.luogu.com.cn/problem/P2827 题目大意 有nnn条蚯蚓&#xff0c;每次选取最长的一条&#xff0c;切成⌊x∗p⌋\lfloor x*p\rfloor⌊x∗p⌋和x−⌊x∗p⌋x-\lfloor x*p\rfloorx−⌊x∗p⌋的两…

.net core DI 注册 Lazy 类型

当我们在 .net core (2.1) 中运行如下代码注入 Lazy<T> 变量的时候&#xff1a;public AccountService(Lazy<IHttpContextAccessor> httpContextAccessor) { }可能会遇到这样的错误提示&#xff1a;InvalidOperationException: Unable to resolve service for type…

【深搜】 棋盘 【NOIp普及组 2017 第三题】 (luogu 3956/ssl 2851)

棋盘棋盘棋盘 题目大意&#xff1a; 有一个M*M的棋盘&#xff0c;要从&#xff08;1&#xff0c;1&#xff09;到&#xff08;m,m&#xff09;&#xff0c;中间有n个有颜色的格子&#xff0c;只能踩在有颜色的格子上&#xff0c;跳到不同颜色的格子要花费1元&#xff0c;可以将…

别跟我谈EF抵抗并发,敢问你到底会不会用EntityFramework

前言一直以来写的博文都是比较温婉型的博文&#xff0c;今天这篇博文算是一篇批判性博文&#xff0c;有问题欢迎探讨&#xff0c;如标题&#xff0c;你到底会不会用EntityFramework啊。你到底会不会用EntityFramework啊面试过三年至六年的同行&#xff0c;作为过面试者到如今作…

【动态规划】 多米诺骨牌 (ssl 1632/luogu 1282)

多米诺骨牌多米诺骨牌多米诺骨牌 Description Input 输入文件的第一行是一个正整数n(1≤n≤1000)&#xff0c;表示多米诺骨牌数。接下来的n行表示n个多米诺骨牌的点数。每行有两个用空格隔开的正整数&#xff0c;表示多米诺骨牌上下方块中的点数a和b&#xff0c;且1≤a&#…