NOIP 装箱问题

news2024/11/25 4:45:32

题目:[NOIP2001]装箱问题 ,哈哈,我们今天来看一道很古老的题嘛,这是选自NOIP上的一道题,好了,我们一起来看看题意吧:

考虑到直接复制题目,或者截屏的方式不是很方便阅读,我就把直接题目链接放下面!
题目传送门: [NOIP2001]装箱问题

思路:

写过01背包的老板看到这道题时,嘴角微微上扬,说,这还不简单,分分钟AC😎

但是,我这里用另一种动态规划的思路

先说说为什么要用动态规划吧:如果用暴力法的话(枚举每个物品装箱还是不装箱),时间复杂度会很高 O(2^n) 😗, 我们需要降低时间复杂度。

举个例子:背包容量 20, 5个物品,体积分别为,1,2,2,4,5 ,若我们枚举每个物品放不放的话,时间复杂度是 2^5 ,我们思考下,可以发现我们放两个体积为2的物品和放一个体积为4的物品,对结果是没有影响的。 我们算出这些物品可以放出的体积有: 1,2,3,4,5,6,7,8,9,10,11,12,13,14 这里一共14次(不排除算错的可能哈😂),而暴力法的话,有32种情况。

我们采用动态规划的思想呢,时间复杂度为:物品个数*背包体积

我们来看看成功AC的代码吧:

二维数组版

#include<bits/stdc++.h>
using namespace std;
int n,total;
int v[20010];
int f[35][20010];
int main(){
    f[0][0]=1;
    cin>>total>>n;
    for(int i=1;i<=n;i++) cin>>v[i];
    /**
     * f[i][j] 表示 0到i 的物品能否填满容量为 j 的背包
     */
     for(int i=1;i<=n;i++){
         for(int j=0;j<=total;j++){
             // f[i-1][j] 就表示前面 i-1 件物品能否填满容量为j的背包
             // f[i-1][j-v[i]] 表示前面 i-1 件物品能否填满容量为j-v[i]的背包
             if(j>=v[i]) f[i][j]=f[i-1][j]||f[i-1][j-v[i]];
             else f[i][j]=f[i-1][j];
         }
     }
     int ans=0;
     for(int i=total;i>=0;i--){
         if(f[n][i]==1){
             ans = i;break;
         }
     }
     cout<<total-ans;
    return 0;
}

我这里放一张雨巨的图,便于大家理解

image-20221128192238173

我们可以看到每一行的结果实际上只与上一行有关,所以啊,我们可以压缩一下

压缩时有个坑:我们遍历体积的时候,需要从大到小去遍历,这样是为了防止让一个物品多次放入背包(这波操作真的很有意思😜)

下面我直接放代码

一维数组版

#include<bits/stdc++.h>
using namespace std;
int n,total;
int v[20010];
int f[20010];
int main(){
    f[0]=1;
    cin>>total>>n;
    for(int i=1;i<=n;i++) cin>>v[i];
    for(int i=1;i<=n;i++){
         for(int j=total;j>=v[i];j--){
             f[j]=f[j]||f[j-v[i]];
         }
     }
     int ans=0;
     for(int i=total;i>=0;i--){
         if(f[i]==1){
             ans = i;break;
         }
     }
     cout<<total-ans;
    return 0;
}

谢谢你的阅读,希望能够帮助你更好的理解动态规划,由于作者水平有限,也难免有不足之处,若读者发现问题,还请批评,在留言区留言或者私信告知,我一定会尽快修改的。若各位大佬有什么好的解法,或者有意义的解法都可以在评论区展示额,万分谢谢。
写作不易,各位老板的肯定和关注都是我坚持下去的动力😘

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

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

相关文章

常见的网络协议

目录 一、TCP/IP协议簇 二、网络设备与五层模型对应关系&#xff1a; 三、常用网络协议总结&#xff08;TCP/IP协议簇&#xff09; 四、应用层服务协议 五、传输层协议组 TCP_UDP 六、网络层协议 IP_ICMP_ARP 七、物理层协议 MAC子层协议 一、TCP/IP协议簇 OSI七层模型…

视频怎么转换为音频文件?快来掌握这几种方式

大家平时在下载网课资源进行学习的时候&#xff0c;看久了眼睛也会开始疲劳&#xff0c;而且有些视频的画面看起来很枯燥。其实我们可以使用一些软件把视频中的音频分离出来&#xff0c;直接收听音频也可以学到知识&#xff0c;而且我们还可以处理其他的事情&#xff0c;是不是…

《计算机体系结构量化研究方法第六版》1.5 集成电路中的功耗和能耗趋势

1.5.1 功耗和能耗&#xff1a;系统视角 Q1&#xff1a;处理器需要的最大功耗是多少&#xff1f; 如果处理器的预期功耗大于电源系统能够提供的功耗&#xff08;试图汲取的电流大于电源系统可以提供的电流&#xff09;&#xff0c;通常会导致电压下降而让器件无法工作。在峰值…

食谱类小程序开发,升级美食服务质量

网络时代&#xff0c;人们可以在网上快速获取到各种资源信息&#xff0c;疫情的影响让人们被封控在家里出不了门&#xff0c;这也就给人们提供了一个回归厨房的契机&#xff0c;很多人在此期间开启了自己的美食制作之旅&#xff0c;朋友圈也变成了一个美食分享社区&#xff0c;…

AlphaFold2源码解析(1)--安装使用

AlphaFold2源码解析(1)–安装使用 AlphaFold2有两种安装方式&#xff1a; 具体可以参考我之前写的博客&#xff1a; Alphafold docker 安装: 参考GitHub&#xff1a;https://github.com/deepmind/alphafold 一步一步安装就可以了&#xff0c; Alphafold 非docker 安装指南 如…

基于PHP+MySQL蚕豆酱厂管理系统的设计与实现

论文阐述了安庆市胡玉美蚕豆酱厂管理系统的设计与实现&#xff0c;并对该系统的需求分析及系统需要实现的设计方法作了介绍。该系统的基本功能包括用户登录&#xff0c;管理员信息管理&#xff0c;车间主任信息管理&#xff0c;采购员信息管理&#xff0c;生产计划管理&#xf…

【正点原子FPGA连载】 第十七章 HDMI彩条显示实验摘自【正点原子】DFZU2EG/4EV MPSoC 之FPGA开发指南V1.0

1&#xff09;实验平台&#xff1a;正点原子MPSoC开发板 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id692450874670 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html 第十七章 HDMI彩…

基于PLC控制四自由度气动式机械手设计

目 录 1 绪论 1 1.1 机械手的概述 1 1.2 机械手的发展史 1 1.3 气动技术及气动机械手的发展过程 2 1.4 机械手未来的发展趋势 3 1.5 本课题研究内容 4 1.6 课题研究的意义 4 2 机械手的总体设计方案 6 2.1 机械手的工作原理及系统组成 6 2.2 机械手基本形式的选择 7 2.3 驱动机…

VO, DTO, DO, PO四胞胎傻傻分不清楚?那快来看这篇文章!

概念 VO(View Object) 视图对象&#xff0c;用于展示层&#xff0c;作用是把某个指定页面&#xff08;或组件的所有数据封装起来&#xff09;。 DTO(Data Transfer Object) 数据传输对象&#xff0c;这个概念来源于J2EE的设计模式&#xff0c;原来的目的是为了给EJB&#x…

第2关:创建表

为了完成本关任务&#xff0c;你需要掌握&#xff1a;如何使用HBase shell指令创建表。 Hbase shell操作 启动HBase之后&#xff0c;我们输入hbase shell进入到Hbase shell命令行窗口&#xff1a; hbase shell 在这里我们输入hbase shell会启动一个加入了一些Hbase特有命令的…

list模拟实现(15)

目录 1、简单框架 1、list.h 2、test.cpp 2、list迭代器实现 1、list.h 2、test.cpp 3、思考 1、迭代器中的拷贝构造和赋值重载是否需要自己实现&#xff1f;析构呢&#xff1f; 2、体会类型的力量 3、const迭代器实现 1、list.h 2、test.cpp 4、重载迭代器的oper…

【附源码】计算机毕业设计JAVA知识库系统

【附源码】计算机毕业设计JAVA知识库系统 目运行 环境项配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; JAVA mybatis …

python 使用enumerate()函数详解

一、enumerate() 函数简介 enumerate()是python的内置函数&#xff0c;将一个可遍历iterable数据对象(如list列表、tuple元组或str字符串)组合为一个索引序列&#xff0c;同时列出数据和数据下标&#xff0c;一般用在for循环当中。 函数返回一个enumerate对象&#xff0c;是一…

Metabase学习教程:仪表盘-4

交叉筛选&#xff1a;图表联动更新仪表盘筛选器 只需单击几下&#xff0c;就可以配置任何图表或表以更新仪表盘筛选器。 Metabase允许您自定义当您单击仪表盘部件。本文将详细介绍如何设置部件更新仪表盘上筛选器在我们称之为交叉筛选. 下面是我们要连接的仪表盘&#xff1a…

如何使用轻量应用服务器搭建Veno File Manager个人私有云网盘?

之前有介绍过使用可道云搭建个人云网盘系统&#xff1a;如何使用闲置的云服务器搭建一个属于自己的可道云私人云网盘&#xff0c;这个教程我将介绍使用Veno File Manager搭建个人云网盘&#xff0c;搭建的过程很相似&#xff0c;都采用的是宝塔面板作为辅助&#xff0c;可道云搭…

40 行 Python 代码,写一个 CPU

一、引言 CPU 如何工作&#xff1f;是困扰初级用户一个迷雾般的难题。我们可能知道诸如程序计数器、RAM、寄存器的只言片语&#xff0c;但尚未对这些部件的工作原理及整个系统的协同有清晰和总体的认识。 本文使用四十行 Python 代码来实现一个最简单的 CPU。使它可编程&…

红眼睛微型成像仪拍照、存储与参数复位

拍照在 IFD-x 设备中有两种含义&#xff0c;一是将照片保存于设备内部的存储器&#xff08;硬拍照&#xff09;&#xff0c;二是将照片 保存于计算机或者手机&#xff08;软拍照&#xff09;。 &#xff08;1&#xff09;硬拍照 有两种方法来触发一次硬拍照&#xff0c;一…

【树莓派不吃灰】Linux篇⑩ 学习例行性工作排程(核心概念)

目录1. 什么是例行性工作排程2. 仅运行一次的工作排程3. 循环运行的例行性工作排程4. 可唤醒停机期间的工作任务5. 重点回顾❤️ 博客主页 单片机菜鸟哥&#xff0c;一个野生非专业硬件IOT爱好者 ❤️❤️ 本篇创建记录 2022-11-28 ❤️❤️ 本篇更新记录 2022-11-28 ❤️&…

5、python中的文件操作

文章目录文件操作介绍文件的打开操作open()文件的关闭操作os模块关于操作系统关于路径json模块将python对象编码成json字符串序列化和反序列化常用参数将json字符串解码为python对象存储为excel文件文件操作介绍 文件的作用&#xff1a;数据的持久化存储 一个程序在运行过程中…

小满Vue3第四十六章(Proxy跨域)

1.首先我们先了解一下什么是跨域 主要是出于浏览器的同源策略限制&#xff0c;它是浏览器最核心也最基本的安全功能。 当一个请求url的 协议、域名、端口 三者之间任意一个与当前页面url不同即为跨域。 例如 xxxx.com -> xxxx.com 存在跨域 协议不同 例如 127.x.x.x:800…