代码随想录 Day37 完全背包理论基础 卡码网T52 LeetCode T518 零钱兑换II T377 组合总和IV

完全背包理论基础

0-1背包理论基础:0-1背包理论基础

完全背包就是在0-1背包的基础上加上了一个条件,0-1背包中每个物品只能选择一次,而在完全背包上一个物品可以选择多次,其实也很简单,只需要修改一部分的代码就可以实现,没了解过0-1背包的友友可以去看我的0-1背包理论基础,下面我们开始分析他们的不同点.

两者的唯一区别就在遍历顺序上(基于一维数组方式讲解)

0-1背包选择先遍历物品,再遍历背包,同时在遍历背包的时候采用倒序遍历,目的就是保证每个物品只被使用一次,其实我们只需要修改成正序遍历即可,这时候,每个物品就可以被多次添加了. 

我们还是举个例子说明

我们的背包容量是4,可以装一下物品,物品数量无限

此时我们尝试先遍历物品后遍历背包和先遍历背包后遍历物品两种方式

1.先物品后背包

我们发现其实dp数组的更新顺序是从左向右的,只与它的前一个状态有关.

2.先背包后物品

这里其实就是列向更新数据,从上向下更新数据,也只与前一个状态有关.

所以这里的遍历顺序是两种都可以.

卡码网T52 携带研究材料

题目链接:题目页面 (kamacoder.com)

题目思路:

和之前一样,利用动规五部曲解决问题,这题是一道标准的完全背包问题

不过在卡码网上需要自己手动进行输入输出和导包

1.dp数组含义

这里dp数组的含义是装满行李箱的研究材料的最大价值

2.递推公式

和0-1背包是一样的,这里不做过多赘述

dp[j] = Math.max(dp[j],dp[j-weight[i]]+value[i]);

3.初始化

dp[0] = 0;是一个默认的初始化,所以直接不用写就行.

4.遍历顺序

这里上面说了,先遍历背包和先遍历物品都是可以的,但是要注意遍历背包的时候是从小往大遍历,不需要倒序遍历了.因为倒徐遍历会默认将价值最大的物品只加入一个进入dp[j]的坐标中,具体可以自己模拟试试看或者参考我对0-1背包的理解

5.打印dp数组排错

代码解析:

import java.util.*;public class Main {public static void main (String[] args) {Scanner sc = new Scanner(System.in);int N = sc.nextInt();int V = sc.nextInt();int[] dp = new int[V+1];int[] weight = new int[N];int[] value = new int[N];int i = 0;while(sc.hasNext()){weight[i] = sc.nextInt();value[i] = sc.nextInt();if(i == N-1){break;}i++;}for(i = 0;i<N;i++){for(int j = weight[i];j<=V;j++){dp[j] = Math.max(dp[j],dp[j-weight[i]]+value[i]);}}System.out.println(dp[V]);}
}

LeetCode T518 零钱兑换II

题目链接:518. 零钱兑换 II - 力扣(LeetCode)

 

题目思路:

这题我们发现和昨天的目标和是类似的,都是求和为一个数字有多少种方式,所以我们自然而然就能想出他的递推公式的dp[j]+=dp[j-coins[i]];  实际上就是将之前的方法数累加,我们要明确这里

1.dp[j]的含义:

凑成总金额j的货币组合数为dp[j]

2.确定dp数组的递推公式

dp[j]+=dp[j-coins[i]];

3.初始化数化

初始化为0即可,在后面遍历的时候会进行覆盖的

4.确定遍历顺序

这里我们思考一个问题,这题中我们要找的是组合数而不是排列数,那么我们就需要保证这里的coins[0]一定不能在coins[1]之后再出现

所以我们这里使用先物品后背包再合适不过了

5.打印dp数组

题目代码:

class Solution {public int change(int amount, int[] coins) {int[] dp = new int[amount+1];dp[0] = 1;for(int i = 0;i<coins.length;i++){for(int j = coins[i];j<=amount;j++){dp[j] += dp[j-coins[i]];}}return dp[amount];}
}

LeetCode T377 组合总和IV

题目链接:377. 组合总和 Ⅳ - 力扣(LeetCode)

 

题目思路:

注意看下面的一个测试用例:(1,3)和(3,1)同时出现了,这说明本题和上一题的唯一区别就是求的是排列数而不是组合数,和数的选取顺序是有关的

1.确定dp数组含义

dp数组的含义是能凑成这个排列数的取值种类有多少种

2.dp数组的递推公式

dp[i] += dp[i-nums[j]];

3.dp数组的初始化

dp[0] = 1;

4.遍历顺序

关键就在于这里,我们使用先遍历背包再遍历物品,这样背包容量为1的遍历了一次全部物品

背包容量为2的也遍历的一次全部物品,所以这里的物品1和物品2的选取不再有序,也就构成了我们的排列数

注:在使用这个递推公式之前记得判断i-nums[j]的大小,避免出现负数

5.打印排错

题目代码:

class Solution {public int combinationSum4(int[] nums, int target) {int[] dp = new int[target+1];dp[0] = 1;for(int i = 1;i<=target;i++){for(int j = 0;j<nums.length;j++){if(i>=nums[j]){dp[i]+=dp[i-nums[j]];}}}return dp[target];}
}

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

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

相关文章

74HC138逻辑芯片

文章目录 74系列逻辑芯片——74HC138基础信息描述特征应用范围 功能信息封装引脚基本电路 扩展性能分析 74系列逻辑芯片——74HC138 基础信息 描述 74HC138器件设计用于需要极短传播延迟时间的高性能存储器解码或数据路由应用&#xff1b;在高性能存储系统中&#xff0c;可使用…

Microsoft Dynamics 365 CE 扩展定制 - 5. 外部集成

本章内容包括: 使用.NET从其他系统连接到Dynamics 365使用OData(Java)从其他系统连接到Dynamics 365使用外部库从外部源检索数据使用web应用程序连接到Dynamics 365运行Azure计划任务设置Azure Service Bus终结点与Azure Service Bus构建近乎实时的集成使用来自Azure服务总线…

结合组件库实现table组件树状数据的增删改

如图所示&#xff0c;可以实现树状数据的新增子项&#xff0c;新增平级&#xff0c;删除。主要用到了递归 代码&#xff1a; <template><el-table :data"tableData" style"width: 100%; margin-bottom: 20px" row-key"id" border def…

代码随想录算法训练营第11天|20. 有效的括号 1047. 删除字符串中的所有相邻重复项 150. 逆波兰表达式求值

JAVA代码编写 20. 有效的括号 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有效字符串需满足&#xff1a; 左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括…

[2016-2018]phpstudy的exp制作

[2016-2018]phpstudy的exp制作 用python的requests模块进行编写 修改请求数据包进行远程代码执行 import requests import base64 def remove_code_execute():try:url input("请输入要测试的网址:")cmd input("想要执行的命令:")cmd f"system({…

Adobe After Effects 2024(Ae2024)在新版本中的升级有哪些?

After Effects 2024是Adobe公司推出的一款视频处理软件&#xff0c;它适用于从事设计和视频特技的机构&#xff0c;包括电视台、动画制作公司、个人后期制作工作室以及多媒体工作室。通过After Effects&#xff0c;用户可以高效且精确地创建无数种引人注目的动态图形和震撼人心…

“深入理解Nginx的负载均衡与动静分离“

目录 引言一、Nginx简介1. Nginx的基本概念2. Nginx的特点3. Nginx的安装配置 二、Nginx搭载负载均衡三、前端项目打包四、Nginx部署前后端分离项目&#xff0c;同时实现负载均衡和动静分离总结 引言 在现代互联网应用中&#xff0c;高性能和可扩展性是至关重要的。Nginx作为一…

[SSD综述 1.4] SSD固态硬盘的架构和功能导论

依公知及经验整理,原创保护,禁止转载。 专栏 《SSD入门到精通系列》 <<<< 返回总目录 <<<< ​ 前言 机械硬盘的存储系统由于内部结构, 其IO访问性能无法进一步提高,CPU与存储器之间的性能差距逐渐扩大。以Nand Flash为存储介质的固态硬盘技术的发展,…

css 图片好玩的一个属性,添加滤镜

鼠标经过效果对比&#xff1a; 上图是改变了图片的饱和度&#xff0c;代码如下&#xff1a; .img-box .v-image:hover {filter: saturate(1.75); }其他滤镜说明如下图&#xff1a;

Hive 解析 JSON 字符串数据的实现方式

文章目录 通过方法解析现实示例 通过序列化实现示例 通过方法解析现实 在 Hive 中提供了直接解析 JSON 字符串数据的方法 get_json_object(json_txt, path)&#xff0c;该方法参数解析如下&#xff1a; json_txt&#xff1a;顾名思义&#xff0c;就是 JSON 字符串&#xff1b;…

vue+asp.net Web api前后端分离项目发布部署

一、前后端项目介绍 1.前端项目是使用vue脚手架进行创建的。 脚手架版本&#xff1a;vue/cli 5.0.8 编译器版本&#xff1a;vs code 1.82.2 2.后端是一个asp.net Core Web API 项目 后端框架版本&#xff1a;.NET 6.0 编译器版本&#xff1a;vs 2022 二、发布部署步骤 第…

东北大学python大作业

目前金属矿开采&#xff0c;爆破还是主要的破岩方式&#xff0c;为了保证巷道采场的安全&#xff0c;需要对爆破震动进行监测&#xff0c;获取的监测数据如附件&#xff0c;第1列数据为震动的序号&#xff0c;第2、3、4列为x,y,z三个方向的震动速度&#xff0c;往往由于各种因素…