【Day50】代码随想录之动态规划完全背包_70. 爬楼梯进阶_322. 零钱兑换 _279.完全平方数

本文主要是介绍【Day50】代码随想录之动态规划完全背包_70. 爬楼梯进阶_322. 零钱兑换 _279.完全平方数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

      • 动态规划理论基础
        • 动规五部曲:
        • 出现结果不正确:
      • 70. 爬楼梯进阶
      • 322. 零钱兑换
      • 279.完全平方数

动态规划理论基础

动规五部曲:
  1. 确定dp数组 下标及dp[i] 的含义。
  2. 递推公式:比如斐波那契数列 dp[i] = dp[i-1] + dp[i-2]。
  3. 初始化dp数组。
  4. 确定遍历顺序:从前到后or其他。
  5. 打印。
出现结果不正确:
  1. 打印dp日志和自己想的一样:递推公式、初始化或者遍历顺序出错。
  2. 打印dp日志和自己想的不一样:代码实现细节出现问题。

70. 爬楼梯进阶

参考文档:代码随想录

分析:
根据题目描述是完全背包的排列问题,遍历顺序为先背包再物品。
dp五部曲:

  1. dp[i]含义:爬到j楼的方法个数。
  2. 递推公式:dp[i] += dp[i-j];
  3. 初始化:dp[0] = 1, 其余位置为0。
  4. 遍历顺序:先背包再物品。

代码:

#include<iostream>
#include<stdio.h>
#include<vector>using namespace std;int main(){int m = 0, n = 0;scanf("%d%d",&n, &m);vector<int> dp(n+1, 0);dp[0] = 1;for(int i = 1; i <= n; i++){//先背包for(int j = 1; j <= m; j++){//再物品if(i >= j) dp[i] += dp[i-j];}}printf("%d", dp[n]);return 0;
}

322. 零钱兑换

参考文档:代码随想录

分析:
dp公式:dp[j] = min(dp[j], dp[j-coins[i]]+1)。
因为题目求的是最少的硬币个数,所以排列组合都可以,即物品和背包的遍历顺序均可。
初始化需要注意dp[0]是0,其余的为了不影响之后的取最小值,定义为32位数的最大值INT_MAX。

代码:

class Solution {
public:int coinChange(vector<int>& coins, int amount) {//dp[j]:amount=j需要的最少硬币个数//dp[j] = min(dp[j], dp[j-coins[i]]+1);//dp[0] = 0, 其他初始化INT_MAXvector<double> dp(amount+1, INT_MAX);dp[0] = 0;for(int i = 0; i < coins.size(); i++){for(int j = coins[i]; j <= amount; j++){dp[j] = min(dp[j], dp[j-coins[i]]+1);}}if(dp[amount] == INT_MAX) return -1;return dp[amount];}
};

279.完全平方数

参考文档:代码随想录

分析:
dp公式改变:dp[j] = min(dp[j], dp[j-i*i]+1);

代码:

class Solution {
public:int numSquares(int n) {//dp[j]: 和为j的完全平方数的最少数量//dp[j] = min(dp[j], dp[j-i*i]+1);//初始化:dp[0] = 0,其余初始化是INT_MAXint nums = n/2;if(n == 1) nums = 1;vector<double> dp(n+1, INT_MAX);dp[0] = 0;for(int i = 1; i <= nums; i++){for(int j = i*i; j <= n; j++){dp[j] = min(dp[j], dp[j-i*i]+1);}}return dp[n];}
};

这篇关于【Day50】代码随想录之动态规划完全背包_70. 爬楼梯进阶_322. 零钱兑换 _279.完全平方数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

从入门到精通详解Python虚拟环境完全指南

《从入门到精通详解Python虚拟环境完全指南》Python虚拟环境是一个独立的Python运行环境,它允许你为不同的项目创建隔离的Python环境,下面小编就来和大家详细介绍一下吧... 目录什么是python虚拟环境一、使用venv创建和管理虚拟环境1.1 创建虚拟环境1.2 激活虚拟环境1.3 验证虚

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、