代码随想录算法训练营第四十三天 | 完全背包理论基础、518.零钱兑换II、377. 组合总和 Ⅳ、70. 爬楼梯 (进阶)

本文主要是介绍代码随想录算法训练营第四十三天 | 完全背包理论基础、518.零钱兑换II、377. 组合总和 Ⅳ、70. 爬楼梯 (进阶),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

完全背包理论基础

题目链接:https://kamacoder.com/problempage.php?pid=1052
文档讲解:https://programmercarl.com/%E8%83%8C%E5%8C%85%E9%97%AE%E9%A2%98%E7%90%86%E8%AE%BA%E5%9F…
视频讲解:https://www.bilibili.com/video/BV1uK411o7c9/

思路

完全背包中,每个物品可以使用无限次。遍历顺序为顺序遍历物品和顺序遍历背包,并且两个for循环可以交换顺序。

for (int i = 0; i < weight.length; i++) {for (int j = weight[i]; j <= bagWeight; j++){dp[j] = Math.max(dp[j], dp[j - weight[i]] + value[i]);}
}

代码

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

518.零钱兑换II

题目链接:https://leetcode.cn/problems/coin-change-ii/
文档讲解:https://programmercarl.com/0518.%E9%9B%B6%E9%92%B1%E5%85%91%E6%8D…
视频讲解:https://www.bilibili.com/video/BV1KM411k75j/

思路

  • 确定dp数组以及下标的含义:凑成j块钱有dp[j]种方法。
  • 确定递推公式:计算方法数要用累加,公式为dp[j] += dp[j - coins[i]];
  • dp数组如何初始化:dp[0] = 1;,否则累加出来都是0。
  • 确定遍历顺序:完全背包问题中,物品和背包都是正序遍历。本题要求的是组合数,需要先遍历物品,再遍历背包;如果是求排列数,就需要先遍历背包,再遍历物品。
  • 打印dp数组,用于debug

代码

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];}
}

分析:时间复杂度:O(mn),空间复杂度:O(m)。其中 m 是 amount,n 是 coins 的长度。

377. 组合总和 Ⅳ

题目链接:https://leetcode.cn/problems/combination-sum-iv/
文档讲解:https://programmercarl.com/0377.%E7%BB%84%E5%90%88%E6%80%BB%E5%92%8C%E2%85%A3.html
视频讲解:https://www.bilibili.com/video/BV1V14y1n7B6/

思路

  • 确定dp数组以及下标的含义:能够凑成目标整数j的组合数为dp[j]
  • 确定递推公式:计算方法数要用累加,公式为dp[j] += dp[j - nums[i]];
  • dp数组如何初始化:dp[0] = 1;,否则累加出来都是0。
  • 确定遍历顺序:完全背包问题中,物品和背包都是正序遍历。本题要求的是排列数,需要先遍历背包,再遍历物品;如果是求组合数,就需要先遍历物品,再遍历背包。
  • 打印dp数组,用于debug

代码

class Solution {public int combinationSum4(int[] nums, int target) {int[] dp = new int[target + 1];dp[0] = 1;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];}
}

分析:时间复杂度:O(mn),空间复杂度:O(m)。其中m是target,n是nums的长度。

70. 爬楼梯 (进阶)

题目链接:https://kamacoder.com/problempage.php?pid=1067
文档讲解:https://programmercarl.com/0070.%E7%88%AC%E6%A5%BC%E6%A2%AF%E5%AE%8C%E5%85%A8%E8%83%8C%E5…

思路

  • 确定dp数组以及下标的含义:爬j阶台阶的方法有dp[j]种。
  • 确定递推公式:计算方法数要用累加,公式为dp[j] += dp[j - i];
  • dp数组如何初始化:dp[0] = 1;,否则累加出来都是0。
  • 确定遍历顺序:完全背包问题中,物品和背包都是正序遍历。本题要求的是排列数,需要先遍历背包,再遍历物品;如果是求组合数,就需要先遍历物品,再遍历背包。
  • 打印dp数组,用于debug

代码

import java.util.*;public class Main{public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt();int m = in.nextInt();int[] dp = new int[n + 1];dp[0] = 1;for (int j = 0; j <= n; j++) {for (int i = 1; i <= m; i++) {if (j >= i) dp[j] += dp[j - i];   }}System.out.println(dp[n]);}
}

分析:时间复杂度:O(mn),空间复杂度:O(n)。

这篇关于代码随想录算法训练营第四十三天 | 完全背包理论基础、518.零钱兑换II、377. 组合总和 Ⅳ、70. 爬楼梯 (进阶)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下