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

news2024/11/26 8:21:36

完全背包理论基础

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.coloradmin.cn/o/1170717.html

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

相关文章

雷池WAF社区版的使用教程

最近听说了一款免费又好用的WAF软件&#xff0c;雷池社区版&#xff0c;体验了一下虽然还有很多改进的空间 但是总体来说很适合小站长使用&#xff0c;和学习使用 也建议所有想学防火墙和红队&#xff08;攻击队&#xff09;练习使用&#xff0c;听说给官网提交绕过还有额外的…

策略模式在数据接收和发送场景的应用

在本篇文章中&#xff0c;我们介绍了策略模式&#xff0c;并在数据接收和发送场景中使用了策略模式。 背景 在最近项目中&#xff0c;需要与外部系统进行数据交互&#xff0c;刚开始交互的系统较为单一&#xff0c;刚开始设计方案时打算使用了if else 进行判断&#xff1a; if(…

uniapp原生插件之安卓文字转拼音原生插件

插件介绍 安卓文字转拼音插件&#xff0c;支持转换为声调模式和非声调模式&#xff0c;支持繁体和简体互相转换 插件地址 安卓文字转拼音原生插件 - DCloud 插件市场 超级福利 uniapp 插件购买超级福利 详细使用文档 uniapp 安卓文字转拼音原生插件 用法 在需要使用插…

新兴初创企业参展招募

一般来说&#xff0c;创业公司的生存率较低&#xff0c;失败率较高。根据不同的数据来源&#xff0c;创业公司的失败率高达 80%-90%。据统计&#xff0c;在中国每年新注册的企业数量超过 100 万家&#xff0c;但能够存活到 5 年以上的企业不足 7%&#xff0c;10 年以上不足 2%。…

Win10系统下查询WiFi强度信息

netsh wlan show networks modebssid 查询周围所有WiFi 可以获取到信号的强度 netsh wlan show interface查询当前网卡连接的wifi 对应的信号强度 具体见图

Hadoop学习总结(Shell操作)

HDFS Shell 参数 命令参数功能描述-ls查看指定路径的目录结构-du统计目录下所有文件大小-mv移动文件-cp复制文件-rm删除文件 / 空白文件夹-put上传文件-cat查看内容文件-text将源文件输出文本格式-mkdir创建空白文件夹-help帮助 一、ls 命令 ls 命令用于查看指定路径的当前目录…

稳定性测试—fastboot和monkey区别

一、什么是稳定性测试 稳定性测试是指检验程序在一定时间内能否稳定地运行&#xff0c;在不同的场景下能否正常地工作的过程。主要目的是检测崩溃、内存泄漏、堆栈错误等缺陷。 二、Monkey 1.什么是Monkey 是一个命令行工具&#xff0c;通常在adb安卓调试运行&#xff0c;模…

智能化审批:低代码平台助力招聘管理进程

都说流程很重要&#xff0c;确实如此。 企业运营中的内部流程是否高效&#xff0c;很大程度上决定了业务能否获得成功。不过&#xff0c;在各项流程中&#xff0c;还有一个重要“角色”不容忽略——审批&#xff0c;它就像是企业版的“开关按钮”&#xff0c;无论是报销、请假…

spss chi-square test

实验卡方检验_chi-square independence-CSDN博客 VAR01类别

前端难学还是后端难学?系统安全,web安全,网络安全是什么区别?

系统安全&#xff0c;web安全&#xff0c;网络安全是什么区别&#xff1f;三无纬度安全问题 系统安全&#xff0c;可以说是电脑软件的安全问题&#xff0c;比如windows经常提示修复漏洞&#xff0c;是一个安全问题 网页安全&#xff0c;网站安全&#xff0c;比如&#xff0c;…

你知道Python、Pycharm、Anaconda 三者之间的关系吗?

哈喽~大家好呀 Python作为深度学习和人工智能学习的热门语言&#xff0c;你知道Python、Pycharm、Anaconda 三者之间的关系吗&#xff1f;学习一门语言&#xff0c;除了学会其简单的语法之外还需要对其进行运行和实现&#xff0c;才能实现和发挥其功能和作用。下面来介绍运行P…

antv/g6元素之combo

介绍 在 G6 中&#xff0c;“Combo” 是一种特殊的元素&#xff0c;用于组合和展示多个节点元素的一种方式。它通常用于表示一个组或子图&#xff0c;将多个相关节点组织在一起&#xff0c;并在图形中以单一的形状显示。 属性 type&#xff1a;Combo 的类型&#xff0c;通常是…

地理信息系统原理-空间数据结构(7)

​四叉树编码 1.四叉树编码定义 四叉树数据结构是一种对栅格数据的压缩编码方法&#xff0c;其基本思想是将一幅栅格数据层或图像等分为四部分&#xff0c;逐块检查其格网属性值&#xff08;或灰度&#xff09;&#xff1b;如果某个子区的所有格网值都具有相同的值&#xff0…

SOLIDWORKS 2024新功能--SOLIDWORKS Electrical篇

SOLIDWORKS Electrical 对齐零部件 在设计 3D 机柜布局时使用对齐零部件时&#xff0c;可以在图形区域中预览更改。这大大减少了在 3D 机柜布局中对齐 SOLIDWORKS 零部件所需的工作量。对齐零部件 PropertyManager 简化并改进了工作流程。 SOLIDWORKS Electrical 更改多个导…

Java 基础知识:面试官必问的问题

本文重点关注Java编程语言的基础知识&#xff0c;并针对求职面试中常见的问题进行了总结。希望帮助读者准备面试&#xff0c;了解常见的Java基础问题 数据类型 基本类型 byte/8char/16short/16int/32float/32long/64double/64boolean/~ boolean 只有两个值&#xff1a;true、…

海外媒体发稿:如何利用8种出口贸易媒体发稿实现销售突破-华媒舍

出口贸易是许多企业追求业务增长的重要途径。在全球市场上突出自己并吸引潜在客户并非易事。幸运的是&#xff0c;利用出口贸易媒体发稿的机会可以成为推动销售突破的有效策略。本文将介绍8种出口贸易媒体以及如何利用它们发稿推广&#xff0c;从而实现销售突破。 1. 行业媒体…

魔术《4 Kings 折纸》的三重境界(三)——群论描述

早点关注我&#xff0c;精彩不错过&#xff01; 前面两篇讲完了基于奇偶性和集合论基础解释《4 Kings 折纸》的方法&#xff0c;详情请戳&#xff1a; 魔术《4 Kings 折纸》的三重境界&#xff08;二&#xff09;——集合语言和数理逻辑 魔术《4 Kings 折纸》的三重境界&#x…

overleaf里插入中文语句

作业要求是需要插入中文 我直接插入中文生成pdf会报错&#xff1a; 解决办法&#xff1a; overleaf官网里提供了教程&#xff1a;https://www.overleaf.com/learn/latex/Chinese 使用XeLaTeX或者LuaLaTeX进行编译是支持UTF-8编码。所以改变编译器的步骤如下&#xff1a; 点击…

Java web(五):会话技术

文章目录 一、会话跟踪技术二、Cookie三、Session四、Cookie和Session的区别五、项目实战 一、会话跟踪技术 二、Cookie 在JSP页面如何获取Cookie&#xff1f; 方式&#xff1a;${cookie.key.value} //key指存在cookie的键的名称 三、Session Session是基于Cookie实现的&…

安装docker可视化工具:Portainer

文章目录 前言一、安装Portainer&#xff08;docker可视化工具&#xff09;1.拉镜像2. 启动容器3.查看4.访问 总结 前言 一、安装Portainer&#xff08;docker可视化工具&#xff09; 1.拉镜像 docker pull portainer/portainer2. 启动容器 docker run -d -p 8100:8000 -p 9…