【Leetcode】二十、记忆化搜索:零钱兑换
文章目录
- 1、记忆化搜索
- 2、leetcode509:斐波那契数列
- 3、leetcode322:零钱兑换
1、记忆化搜索
也叫备忘录,即把已经计算过的结果存下来,下次再遇到,就直接取,不用重新计算。目的是以减少重复计算。

以前面提到的斐波那契数列为例,计算F(5),拆成F(4) + F(3),接下来递归的顺序,如上图红色箭头,会先算左侧一支,计算完F(4)后,函数往下接着执行,才计算右侧一支的F(3)

可以发现,计算左侧一支的F(4)时,会得到F(3)的值,存下F(3)的值的话,执行到右侧一支计算F(3)时,直接取就行。

考虑初始化一个数组,数组元素为一个题目中不可能出现的值。然后将F(0)存在数组下标为0的地方,F(3)存数组下标为3的地方,计算一个值时,先在数组中找,找不到时再计算。
2、leetcode509:斐波那契数列

用一个int数组,存储计算过的每个F(x),方便后面使用
public class P509Two {public int recursion(int n) {//F(0)和F(1)if (n < 2) {return n == 0 ? 0 : 1;}int[] dp = new int[n + 1];dp[1] = 1; //F(1)// 根据方程式,计算每个值,存入数组,从F(2)一路计算到F(5)for (int i = 2; i <= n; i++) {dp[i] = dp[i - 1] + dp[i - 2];}return dp[n];}
}
当然,这儿也是动态规划。至于二者的在这块儿的区别参考前一篇的爬楼梯那题。动态规划,重在状态转移,那些不用的中间值,存不存在你。记忆化搜索则重在存储已计算结果的方式来避免重复计算。

3、leetcode322:零钱兑换

总金额amount恰好等于硬币面值时,最优解为1:

考虑利用等于硬币面值金额的最优解,推出其他金额的最优解。选择一个面值小于 总金额amount 的硬币之后,剩余金额对应的最优解是已知的,选择这些剩余金额最优解中最小的,再加上对应的那张面值小于i 的硬币,就是总金额amount的最优解。

如上,amount = 3,面值小于amount的硬币有面值为1和面值为2的:
- 如果选择面值为1的,剩余3 - 1 = 2,而2的最优解就是1,那amount的最优解就是 1 + 1 = 2
- 如果选择面值为2的,剩余3 - 2 = 1,而1的最优解就是1,那amount的最优解就是 1 + 1 = 2
因此,amount的最优解是2。如此,amount = 已知面值时,也可以这样推出来,比如amount = 2。同理:

amount = 14的剩余金额中,剩余7时,最优解最小,为1,因此14最优解就是 1 + 1 = 2。以amount14为例,初始化一个amount + 1的dp数组:

根据上面的分析,14有五种写法,选择最小值返回即可:

假设硬币面值有c1、c2、c3,那动态规划的状态转移方程式为:
F(amount) = Min(F(amount - c1) + F(amount - c2) + F(amount - c3)) + 1
有点像动态规划-完全平方数那题。实现(动态规划):
public class P322 {public int coinChange(int[] coins, int amount) {if (null == coins || coins.length == 0) {return 0;}int[] dp = new int[amount + 1];// 填充-1Arrays.fill(dp, -1);// 金额0的最优解dp[0] = 0;for (int i = 1; i <= amount; i++) {// 对于每个金额i,遍历面值集合coinsfor (int coin : coins) {// 如果面值小于等于总金额i,并且剩余金额有最优解if (coin <= i && dp[i - coin] != -1) {// 如果总金额i没有计算过,或者,总金额i的最优解比正在计算的最优解大if (dp[i] == -1 || dp[i] > dp[i - coin] + 1) {// 更新最优解dp[i] = dp[i - coin] + 1;}}}}return dp[amount];}
}
相关文章:
【Leetcode】二十、记忆化搜索:零钱兑换
文章目录 1、记忆化搜索2、leetcode509:斐波那契数列3、leetcode322:零钱兑换 1、记忆化搜索 也叫备忘录,即把已经计算过的结果存下来,下次再遇到,就直接取,不用重新计算。目的是以减少重复计算。 以前面提…...
json数据格式 继续学习
1.定义 轻量级的数据交互格式,可以按照json数据格式去组织和封装数据。 本质是一个带有特定格式的字符串。 2.功能 负责不同编程语言中的数据传递和交互。 3.json数据格式转化 """ 演示json数据和python字典之间的转换 """ impor…...
gradle 构建项目添加版本信息
gradle 构建项目添加版本信息,打包使用 spring boot 的打包插件 build.gradle 配置文件 bootJar {manifest {attributes(Project-Name: project.name,Project-Version: project.version,"project-Vendor": "XXX Corp","Built-By": &…...
vue3 学习笔记17 -- 基于el-menu封装菜单
vue3 学习笔记17 – 基于el-menu封装菜单 前提条件:组件创建完成 配置路由 // src/router/index.ts import { createRouter, createWebHashHistory } from vue-router import type { RouteRecordRaw } from vue-router export const Layout () > import(/lay…...
使用 Redis 实现验证码、token 的存储,用自定义拦截器完成用户认证、并使用双重拦截器解决 token 刷新的问题
可以看一下我以前做过的笔记:黑马点评 短信登录部分 基于session实现登录流程 1.发送验证码 用户在提交手机号后,会校验手机号是否合法,如果不合法,则要求用户重新输入手机号 如果手机号合法,后台此时生成对应的验…...
反转链表 - 力扣(LeetCode)C语言
206. 反转链表 - 力扣(LeetCode)( 点击前面链接即可查看题目) /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/ struct ListNode* reverseList(struct ListNode* head) {if(head NULL)…...
【Linux】进程间通信(1):进程通信概念与匿名管道
人与人之间是如何通信的?举个简单的例子,假如我是月老,我要为素不相识的但又渴望爱情的男女两方牵红线。我需要收集男方的信息告诉女方,收集女方的信息告诉男方,然后由男女双方来决定是否继续。对于他们而言࿰…...
Spring从入门到精通 01
文章目录 1. 依赖注入 (Dependency Injection, DI)2. 面向切面编程 (Aspect-Oriented Programming, AOP)3. 事务管理4. 简化 JDBC 开发5. 集成各种框架和技术6. 模块化和扩展性:主要的 Spring 模块:Core Container:AOP 模块:Data …...
C语言经典习题25
冒泡排序 对一维数组进行升序排序,然后在数组中输入20个数,将排序后的结果打印输出。 #include<stdio.h> #define N 20 int main() {int a[N];int i;for(i0;i<N;i) //初始化数组的数 {scanf("%d",&a);}for(i0;…...
2-47 基于matlab的时域有限差分法(FDTD法)拉夫等效原理进行时谐场外推
基于matlab的时域有限差分法(FDTD法)拉夫等效原理进行时谐场外推。外推边界距离吸收边界的距离、电磁场循环、傅立叶变换提起幅值和相位、各远区剖分点电场、方向系数计算等操作,得出可视化结果。程序已调通,可直接运行。 2-47 时域有限差分法(FDTD法) 拉…...
JupyterNotebook快捷键 自用
COMMAND MODE —————————————————————————————— Up Down cells的上下选择 A B 在上/下方插入cell C V X 复制/粘贴/剪切cell 双击D 删除所选cell Z 恢复被删除的cell 双击I Interrupt中断内核 Shift Enter 运行cell并选择下方 EDIT MODE ———…...
【我的OpenGL学习进阶之旅】讲一讲GL_TEXTURE_2D和GL_TEXTURE_EXTERNAL_OES的区别
在使用OpenGL ES进行图形图像开发时,我们常使用GL_TEXTURE_2D纹理类型,它提供了对标准2D图像的处理能力。这种纹理类型适用于大多数场景,可以用于展示静态贴图、渲染2D图形和进行图像处理等操作。 另外,有时我们需要从Camera或外部视频源读取数据帧并进行处理。这时,我们…...
Makefile 如何将生成的 .o 文件放到指定文件夹
研究了不少文章,我行通了一个,但是也不全,目前只能适用当前文件夹,如果源文件有子文件夹处理不了,还得继续研究。很多人说编译完把O文件移动走或者直接删掉。我想说的是不符合我的要求,移走或者删除O文件&a…...
聊一聊知识图谱结合RAG
因为最近在做一些关于提高公司内部使用的聊天机器人的回答准确率,并且最近微软官方也是开源了一下graphrag的源码,所以想聊一聊这个知识图谱结合rag。 rag在利用私有数据增强大模型回答的领域是一种比较典型的技术,也就是我们提出问题的时候&…...
Java面试锦集 之 一、Java基础(1)
一、Java基础(1) 1.final 关键字的作用? 修饰变量: 一旦被赋值,就不能再被修改,保证了变量值的稳定性。 例: final int NUMBER 10; //之后就不能再改变 NUMBER 的值了。修饰方法:…...
【leetcode】排列序列
给出集合 [1,2,3,...,n],其所有元素共有 n! 种排列。 按大小顺序列出所有排列情况,并一一标记,当 n 3 时, 所有排列如下: "123""132""213""231""312""321" 给定…...
【Cesium开发实战】视频融合功能的实现,可自定义位置和视频路径
Cesium有很多很强大的功能,可以在地球上实现很多炫酷的3D效果。今天给大家分享一个视频融合功能。 1.话不多说,先展示 视频融合 2.设计思路 点击绘制开始在地图上绘制视频融合的点位,形成视频播放的区域,双击弹框输入名称和要播放视频的路径,即可对应区域播放对应视频,…...
【秋招笔试题】小明的美食
解析:思维题。由于需要互不相同,每次操作取重复的值与最大值相加即可,这样即可保证相加后不会新增重复的值。因此统计重复值即可。 #include <iostream> #include <algorithm>using namespace std; const int maxn 1e5 5; int…...
基于OpenLCA、GREET、R语言的生命周期评价方法、模型构建及典型案例应用
生命周期分析 (Life Cycle Analysis, LCA) 是评价一个产品系统生命周期整个阶段——从原材料的提取和加工,到产品生产、包装、市场营销、使用、再使用和产品维护,直至再循环和最终废物处置——的环境影响的工具。这种方法被认为是一种“从摇篮到坟墓”的…...
Linux操作系统 -socket网络通信
同一台主机之间的进程 1.古老的通信方式 无名管道 有名管道 信号 2、IPC对象通信 system v 消息队列 共享内存 信号量集 由于不同主机间进程通信 3.socket网络通信 国际网络体系结构: 七层OSI模型(理论…...
YetiClaw Studio:本地部署AI游戏开发工作室实战指南
1. 项目概述:YetiClaw Studio,一个运行在本地硬件上的AI游戏开发工作室如果你是一个独立游戏开发者,或者是一个小型工作室的成员,那么你一定对游戏开发中那些繁琐、重复但又至关重要的环节深有体会:从最初那个模糊的创…...
基于Rust的高效远程桌面方案:从协议优化到部署实践
1. 项目概述:远程桌面连接的另一条路如果你和我一样,经常需要在Windows电脑上操作远在另一张桌子上的Mac,或者反过来,那么“远程桌面”这个需求就再熟悉不过了。市面上有VNC、微软的RDP,还有各种第三方工具,…...
低速率串行信号调试与MSO应用实战指南
1. 低速率串行信号调试的核心挑战在嵌入式系统设计中,低速率串行信号(Low Speed Serial, LSS)承担着模块间通信的关键任务。与高速信号不同,LSS通常工作在1MHz以下频率,采用UART、I2C、SPI等协议。这类信号看似简单&am…...
基于Matrix的AI助手baibot:多模型集成与隐私优先部署指南
1. 项目概述:一个为Matrix而生的全能AI助手如果你和我一样,既是Matrix去中心化通信的忠实用户,又对当前各种AI大模型的能力感到兴奋,那么你很可能一直在寻找一个能将两者无缝结合的工具。市面上确实有一些方案,比如基于…...
NCE外汇:平台稳定性与用户体验的全面观察
金融服务行业的复杂性决定了平台需要在多个维度上同时具备较高的水准。NCE外汇经过多年的发展,已经在合规、技术、服务、教育等方面形成了一套相互支撑的体系。本文从评测视角出发,对其综合实力进行多维度的解读,呈现一个具有结构感的平台画像…...
月薪8K到年薪80万!这个AI职位一年暴涨985%,普通人如何抓住风口?2026年最火爆的5个岗位+3条入场路径全解析!
文章讲述了AI Agent开发工程师的兴起,年薪可达80万。文章以小李的真实故事为例,展示了通过主动学习AI技术,可以实现职业的巨大转变。文章还分析了Agentic AI的特点及其对就业市场的影响,指出40%的岗位将被重新定义。文章列举了AI …...
夏普鸿海合作破裂启示:跨文化并购中的技术控制与信任危机
1. 一场被寄予厚望的“联姻”为何走向破裂?2012年3月,当日本液晶面板巨头夏普宣布与全球最大电子代工企业鸿海(富士康)达成资本合作时,整个东亚电子产业圈都为之震动。这被视为一个标志性事件:一家以技术自…...
国际B2B企业平台表达框架:IBM式重构与ServiceNow式统一执行
如果把国际B2B品牌表达看成一个系统问题,IBM / ServiceNow这组样本可以拆成一套判断框架。它不是讨论文案怎么写,而是讨论输入什么业务条件,输出什么品牌角色、结构和证据链。框架结论:IBM与ServiceNow都服务企业转型,…...
FPGA在软件无线电系统中的并行处理与动态重配置技术
1. FPGA在软件无线电系统中的核心价值FPGA(现场可编程门阵列)已成为现代软件无线电(SDR)系统的核心处理引擎。与传统DSP处理器相比,FPGA凭借其并行架构和可重构特性,在实时信号处理领域展现出独特优势。在典…...
AwaDB:纯Python实现的轻量级本地向量数据库实践指南
1. 项目概述:当向量数据库遇上本地化与轻量化最近在折腾一些AI应用的原型,特别是RAG(检索增强生成)和智能问答系统,发现向量数据库的选择是个绕不开的话题。市面上有Pinecone、Weaviate这样的云服务,也有Mi…...
