代码随想录算法训练营第四十五天 爬楼梯 (进阶)、322. 零钱兑换、 279.完全平方数

本文主要是介绍代码随想录算法训练营第四十五天 爬楼梯 (进阶)、322. 零钱兑换、 279.完全平方数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码随想录算法训练营第四十五天 | 爬楼梯 (进阶)、322. 零钱兑换、 279.完全平方数

二维爬楼梯 (进阶)

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

爬楼梯的高度n就是背包的容量

每次能爬1 ~ m阶台阶,说明1 ~ m的就是物品的种类

这样就把题目变成了一个完全背包问题:

从1~m中任选(无线数量)求凑成n一共有多少种排列方式?

dp[0]需要初始化为

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

322. 零钱兑换

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

不理解的是,为什么不强调组合还是排列就能不在意遍历顺序

class Solution {public int coinChange(int[] coins, int amount) {if(coins.length == 0){return -1;}int[] dp = new int[amount+1]; // dp[i] 表示凑成金额 i 所需的最少硬币数Arrays.fill(dp, amount + 1); // 将 dp 数组初始化为一个较大的值,确保在后续更新中可以正确比较最小值。dp[0] = 0;  // 凑成金额 0 不需要硬币// 对本题来说,要求的是并不强调集合是 组合 还是 排列!// 所以先遍历 物品 或者 背包都是可行的for(int i = 0; i < coins.length; ++i) {for(int j = coins[i]; j < amount + 1; ++j) {if(dp[j - coins[i]] != amount + 1) {dp[j] = Math.min(dp[j], dp[j - coins[i]] + 1);}}}return dp[amount] > amount ? -1 : dp[amount]; // 表示如果凑成总金额的最少硬币数仍然是初始时的较大值,说明无法凑成总金额}
}

279.完全平方数

题目链接:279. 完全平方数 - 力扣(LeetCode

就是零钱兑换。

class Solution {public int numSquares(int n) {int[] dp = new int[n + 1];Arrays.fill(dp, n + 1);dp[0] = 0;for(int i = 0; i <= Math.sqrt((double) n); ++i) {for(int j = i * i; j <= n; ++j) {if(dp[j - i * i] != n + 1) {dp[j] = Math.min(dp[j], dp[j - i * i] + 1);}}}return dp[n] > n ? -1 : dp[n];}
}

总结

  • 我们要求的集合不强调是 组合 还是 排列 就先物品还是先背包没有要求

  • 强调组合,先物品

  • 强调排列,先背包

这篇关于代码随想录算法训练营第四十五天 爬楼梯 (进阶)、322. 零钱兑换、 279.完全平方数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

基于Python编写自动化邮件发送程序(进阶版)

《基于Python编写自动化邮件发送程序(进阶版)》在数字化时代,自动化邮件发送功能已成为企业和个人提升工作效率的重要工具,本文将使用Python编写一个简单的自动化邮件发送程序,希望对大家有所帮助... 目录理解SMTP协议基础配置开发环境构建邮件发送函数核心逻辑实现完整发送流程添加附件支持功能实现htm

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

SpringBoot集成Shiro+JWT(Hutool)完整代码示例

《SpringBoot集成Shiro+JWT(Hutool)完整代码示例》ApacheShiro是一个强大且易用的Java安全框架,提供了认证、授权、加密和会话管理功能,在现代应用开发中,Shiro因... 目录一、背景介绍1.1 为什么使用Shiro?1.2 为什么需要双Token?二、技术栈组成三、环境

Java 与 LibreOffice 集成开发指南(环境搭建及代码示例)

《Java与LibreOffice集成开发指南(环境搭建及代码示例)》本文介绍Java与LibreOffice的集成方法,涵盖环境配置、API调用、文档转换、UNO桥接及REST接口等技术,提供... 目录1. 引言2. 环境搭建2.1 安装 LibreOffice2.2 配置 Java 开发环境2.3 配

Python跨文件实例化、跨文件调用及导入库示例代码

《Python跨文件实例化、跨文件调用及导入库示例代码》在Python开发过程中,经常会遇到需要在一个工程中调用另一个工程的Python文件的情况,:本文主要介绍Python跨文件实例化、跨文件调... 目录1. 核心对比表格(完整汇总)1.1 自定义模块跨文件调用汇总表1.2 第三方库使用汇总表1.3 导