代码随想录第三十七天(完全背包问题)|完全背包|零钱兑换 II|组合总和 Ⅳ

本文主要是介绍代码随想录第三十七天(完全背包问题)|完全背包|零钱兑换 II|组合总和 Ⅳ,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

完全背包问题

完全背包问题和01背包的区别就在于每一个物品可取的次数,01背包每个物品只能取一次,完全背包每个物品能取无数次。

而01背包为了保证每个物品只取一次,在遍历背包的时候需要倒序遍历,这样才能保证之前的状态都是初始状态,没有添加过物品,利用之前的状态时就不会将同一个物品进行重复添加。

在完全背包中,就需要每个物品能取多次,于是解除遍历背包时的倒序限制就行。

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

在完全背包中,在求装满指定容量背包的组合总数的时候,遍历顺序非常重要,只求组合总数的话,先遍历物品,后遍历背包,因为先遍历物品的话,每次都会将前一个物品先添加进去,只会出现{1,2}这样的组合,不会出现{2,1}的组合。因为当前物品层依赖上一个物品层传递下来的状态,上一个物品层,就只会又上一个物品层和其之前的物品层的组合。不会有之后物品层的值放入组合中。

而将遍历顺序颠倒,先遍历背包,后遍历物品,以物品{1,2,3}为例,装满容量为4的背包,y轴为物品,x轴为背包。

01234
011124
111236
211247

当背包容量为3,假如已取物品1,也就是先放入重量为2的物品,剩余只能取重量为1的组合了,就出现了{2,1},而假如已取的是物品0,也就是先放入重量为1的物品,剩余只能取重量为2的组合,因为在上一个状态遍历了物品1,已经有了重量2的组合,就出现了{1,2}和{1,1,1}的组合了。

零钱兑换 II

题中只要求求组合总数,不讲究顺序。

动规五部曲,改变下遍历顺序

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+1;j++){dp[j]+=dp[j-coins[i]];}}return dp[amount];}
}

组合总和 Ⅳ

讲究顺序

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

这篇关于代码随想录第三十七天(完全背包问题)|完全背包|零钱兑换 II|组合总和 Ⅳ的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/965506

相关文章

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho