代码随想录刷题记录day39 完全背包+零钱兑换 II+组合总和 Ⅳ

news2025/1/2 5:49:17

代码随想录刷题记录day39 完全背包+零钱兑换 II+组合总和 Ⅳ

参考:代码随想录

完全背包

有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品都有无限个(也就是可以放入背包多次),求解将哪些物品装入背包里物品价值总和最大。

和0 1背包的区别就是物品加入的次数,完全背包物品可以加入无限次。

所以遍历顺序需要改变。要从小到大去遍历物品。

// 先遍历物品,再遍历背包
for(int i = 0; i < weight.size(); i++) { // 遍历物品
    for(int j = weight[i]; j <= bagWeight ; j++) { // 遍历背包容量
        dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);

    }
}

遍历顺序是可以颠倒的。

518. 零钱兑换 II

在这里插入图片描述

思想

完全背包问题,集合中的数可以重复放入背包种

设计到遍历顺序

先遍历物品,再遍历背包,是组合顺序

       for(int i=0;i<coins.length;i++){//遍历背包
            for(int j=coins[i];j<=amount;j++){//遍历物品
                dp[j]+=dp[j-coins[i]];
                System.out.println("i:"+i+",j:"+j+",dp[j]:"+dp[j]);
            }
            System.out.println("\b");
        }

打印数组如下:

i:0,j:1dp[j]:1
i:0,j:2dp[j]:1
i:0,j:3dp[j]:1
i:0,j:4dp[j]:1
i:0,j:5dp[j]:1

i:1,j:2dp[j]:2
i:1,j:3dp[j]:2
i:1,j:4dp[j]:3
i:1,j:5dp[j]:3

i:2,j:5dp[j]:4

先遍历背包在遍历物品,是排列顺序

for(int j=0;j<=amount;j++ ){//遍历背包
    for(int i=0;i<coins.length;i++){//遍历物品
        if (j>=coins[i])dp[j]+=dp[j-coins[i]];
        System.out.println("i:"+i+",j:"+j+",dp[j]:"+dp[j]);
    }
    System.out.println("\b");
}

打印数组如下:

i:0,j:0,dp[j]:1
i:1,j:0,dp[j]:1
i:2,j:0,dp[j]:1

i:0,j:1,dp[j]:1
i:1,j:1,dp[j]:1
i:2,j:1,dp[j]:1

i:0,j:2,dp[j]:1
i:1,j:2,dp[j]:2
i:2,j:2,dp[j]:2

i:0,j:3,dp[j]:2
i:1,j:3,dp[j]:3
i:2,j:3,dp[j]:3

i:0,j:4,dp[j]:3
i:1,j:4,dp[j]:5
i:2,j:4,dp[j]:5

i:0,j:5,dp[j]:5
i:1,j:5,dp[j]:8
i:2,j:5,dp[j]:9

代码

public int change(int amount, int[] coins) {

        //dp[j]表示容量为j的背包,有dp[j]种方法。

        //dp[j]+=dp[j-coins[i]]
        int[] dp=new int[amount+1];
        dp[0]=1;

        //递推公式
        //假设背包的容量,j=5,
        // 如果有一个重量1,有dp[4]种方法可以装满背包
        //如果有一个重量2,有dp[3]种方法可以装满背包
        //如果有一个重量3,有dp[2]种方法可以装满背包
        //如果有一个重量4,有dp[1]种方法可以装满背包
        //如果有一个重量5,有dp[0]种方法可以装满背包
        //dp[j]+=dp[j-coins[i]]

        for(int i=0;i<coins.length;i++){//遍历物品
            for(int j=coins[i];j<=amount;j++){//遍历背包
                dp[j]+=dp[j-coins[i]];
                System.out.println("i:"+i+",j:"+j+",dp[j]:"+dp[j]);
            }
            System.out.println("\b");
        }

//        for(int j=0;j<=amount;j++ ){//遍历背包
//            for(int i=0;i<coins.length;i++){//遍历物品
//                if (j>=coins[i])dp[j]+=dp[j-coins[i]];
//                System.out.println("i:"+i+",j:"+j+",dp[j]:"+dp[j]);
//            }
//            System.out.println("\b");
//        }

        return dp[amount];

    }

377. 组合总和 Ⅳ

在这里插入图片描述

思想

就是上一题提到的排列的情况。

但是还没有完全理解呀!!!

动态规划好难~

代码

class Solution {
    public int combinationSum4(int[] nums, int target) {
        //dp[j] 表示容量为j的背包可以 装满有dp[j]种

        int [] dp=new int[target+1];
        dp[0]=1;

        // for(int i=0;i<nums.length;i++){
        //     for(int j=nums[i];j<=target;j++){
        //         dp[j]+=dp[j-nums[i]];
        //         System.out.println(dp[j]);
        //     }
        // }

        for(int j=0;j<=target;j++){
            for(int i=0;i<nums.length;i++){
                if(j>=nums[i])dp[j]+=dp[j-nums[i]];
            }
        }
        return dp[target];

    }
}

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

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

相关文章

《自己动手写CPU》学习记录(6)——第5章/Part 2

目录 引言 致谢 指令说明 逻辑指令 and、or、xor、nor andi、xori lui 移位指令 sll、sllv、sra、srav、srl、srlv 空指令 nop、ssnop、sync、pref 指令实现 宏定义添加 指令译码模块修改 指令执行模块修改 功能验证 逻辑运算 验证代码 仿真波形 移位运算…

CMake中aux_source_directory的使用

CMake中的aux_source_directory命令用于查找目录中的所有源文件&#xff0c;其格式如下&#xff1a; aux_source_directory(<dir> <variable>) 收集指定目录中所有源文件的名称&#xff0c;并将列表(list)存储在提供的<variable>中。该命令旨在由使用显式模…

b2b2c 电子商务平台涉及的技术、运营方案

一个好的SpringCloudSpringBoot b2b2c 电子商务平台涉及哪些技术、运营方案&#xff1f;以下是我结合公司的产品做的总结&#xff0c;希望可以帮助到大家&#xff01; 搜索体验小程序&#xff1a;海哇 1. 涉及平台 平台管理、商家端&#xff08;PC端、手机端&#xff09;、买…

javaee之黑马旅游网3

下面来说一个问题&#xff0c;就是对于一张表的操作&#xff0c;涉及到了很多的servlet页面 比如对于一个user表&#xff0c;里面有很多的相关的servlet页面 如果是这样一种情况&#xff0c;那么user表涉及到七八个页面&#xff0c;category表又涉及到七八个页面&#xff0c;那…

初级软件测试工程师工资(薪资待遇)一般是多少?

那接下来&#xff0c;我们要讲的是从软件测试这个岗位与职责&#xff0c;以及对应的标准薪资范畴 到底软件测试它不同的层次它要负责一些什么样的事情&#xff0c;对于软件测试这个岗位呢&#xff0c;第一个&#xff0c;它要求的东西确实非常的多&#xff0c;比如说你要懂数据…

SpringBoot - WebSocket的使用和聊天室练习

SpringBoot - WebSocket的使用和聊天室练习前言一. SpringBoot整合WebSocket1.1 &#xff08;插曲&#xff09;SpringCloud网关服务接入WebSocket启动错误二. 前端代码监听2.1 模拟进入/离开聊天室2.2 模拟聊天前言 近期准备在我的个人云直播项目中&#xff0c;编写弹幕模块。…

超详细的 pytest 教程(一)使用入门篇

前言 pytest到目前为止还没有翻译的比较好全面的使用文档&#xff0c;很多英文不太好的小伙伴&#xff0c;在学习时看英文文档还是很吃力。本来去年就计划写pytest详细的使用文档的&#xff0c;由于时间关系一直搁置&#xff0c;直到今天才开始写。本文是第一篇&#xff0c;主…

基于jsp+mysql+ssm校园在线投票系统-计算机毕业设计

项目介绍 校园在线投票系统主要包括系统用户管理模块、新闻公告管理模块、投票信息管理、班级信息管理、登录模块、和退出模块等多个模块。系统采用了jsp的mvc框架,SSM(springMvcspringMybatis)框架进行开发,本系统是独立的运行&#xff0c;不依附于其他系统&#xff0c;可移植…

Apipost下载安装和功能详解

一、ApiPost简介 ApiPost PostMan Swagger Mock Jmeter 后端、前端、测试同时在线编辑&#xff0c;同时在线协作&#xff0c;内容实时同步 1.官网地址&#xff1a;https://www.apipost.cn/ 2.官网支持客户端下载及web版在线调试&#xff0c;可根据自己的需求选择适合自己的…

@Controller和@RestController的区别?

本文为joshua317原创文章,转载请注明&#xff1a;转载自joshua317博客 Controller和RestController的区别&#xff1f; - joshua317的博客 Controller和RestController的区别&#xff1f; 在springboot开发中控制层使用注解Controller时&#xff0c;加有GetMapping(PostMappi…

网络开关量输入转4G模块钡铼技术S274

网络开关量输入转4G模块钡铼技术S274支持4路DIN4路DO1路RS485&#xff0c;本机设备自带的继电器 DO 寄存器地址属于保持线圈&#xff0c;地址 0-3&#xff0c;服务器主站发送报文格式&#xff1a; 接收设备返回报文格式&#xff1a; 示例&#xff1a;读取2 个DO状态&#xff…

FS5175AE的PCB布局设计建议

FS5175AE的PCB布局设计建议-基础篇 开关电源的一个常见问题是“不稳定”的开关波形。有时,波形抖动很明显,可以听到从磁性元件发出噪声。如果问题与印刷电路板(PCB)布局有关,则很难确定原因。 EMC也是很注重(PCB)布局,这就是为什么在开关电源设计的早期正确布局PCB至关重要的原…

React 学习笔记:事件处理

React 事件处理 React 采用 on 事件名的方式来绑定一个事件&#xff0c;注意&#xff0c;这里和原生的事件是有区别的&#xff0c;原生的事件全是小写 onclick , React 里的事件是驼峰 onClick 。并且 React 中若想阻止默认事件需要显示的调用 e.preventDefault&#xff0c;而…

智工教育:2023年安全工程师考试习题

答案在最后 1.依据中共中央国务院《关于推进安全生产领域改革发展的意见》&#xff0c;到( )年&#xff0c;实现安全生产治理体系和治理能力现代化&#xff0c;全民安全文明素质全面提升&#xff0c;安全生产保障能力显著增强&#xff0c;为实现中华民族伟大复兴的中国梦奠定稳…

Linux系统IO

文章目录Linux系统IOsysio简介sysio版本的copy示例代码代码说明函数讲解如何编译 运行系统IO与标准IO的区别示例代码函数讲解编译 运行&#xff1f;程序中的重定向代码示例代码说明函数讲解编译 运行&#xff1f;代码示例函数讲解编译 运行Linux系统IO sysio简介 所谓文件IO就…

全国青少年软件编程(Scratch)等级考试二级考试真题2022年6月——持续更新.....

电子学会202206Scratch二级真题及参考答案 1.角色初始位置如图所示&#xff0c;下面哪个选项能让角色移到舞台的左下角&#xff1f;&#xff08; &#xff09; A. B. C. D. 正确答案&#xff1a;C 答案解析&#xff1a; 舞台的左下角&#xff0c;坐标x为负数&#xff0c;…

【数据结构】七大排序

目录 一、什么是稳定性 二、七大排序 2.1基于选择的思想 2.1.1直接选择排序 2.1.2堆排序 2.2基于插入的思想 2.2.1直接插入排序 2.2.2希尔排序 2.3归并排序 2.4基于交换的思想 2.4.1冒泡排序 2.4.2快速排序 三、外部排序 排序就是将一组无序的数据经过一定的算法调…

Linux系统:root用户 登录失败

问题 在Linux系统上&#xff0c;从root用户切换到oracle用户时报错 su: cannot open session: Permission denied 如下&#xff1a; 分析 定位原因1 分析登录日志&#xff0c;可以看到时登录的时候limit中的 memlock 设置失败&#xff0c;导致用户登录失败&#xff1a; limi…

[GO] Gin入门

1. Gin基本使用 1.1 Gin入门 Gin是一个golang的微框架,封装比较优雅,API友好,源码注释比较明确,具有快速灵活,容错方便等特点对于Golang而言,web框架的依赖要远比Python,Java之类要小,自身的net/http足够简单,性能也非常不错借助框架开发,不仅可以省去很多常用的封装带来的时…

为本地web服务配置使用固定的二级子域名【内网穿透】

由于使用免费的cpolar所生成的公网地址为随机临时地址&#xff0c;该地址24小时内会发生变化&#xff0c;对于需要长期访问的用户来讲比较不方便。 不过我们可以为其配置cpolar固定的二级子域名&#xff08;该二级子域名可自定义&#xff09;&#xff0c;该地址不会随机变化&a…