当前位置: 首页 > article >正文

从能算到秒杀:零钱兑换与「最少硬币」的数学真相

如果说279. 完全平方数​ 是在考你最少用几个平方数拼出一个数那322. 零钱兑换​ 就是它的「现实版」最少用几枚硬币凑出一个金额这也是我第一次真正明白一句话所有「最少数量」的问题本质都是最短路径。 题目速览LeetCode 322. 零钱兑换中等给你一个整数数组coins表示不同面额的硬币再给你一个整数amount表示总金额。请你计算凑出 amount 所需的最少硬币个数。每种硬币无限使用如果无法凑出返回-1示例输入coins [1,2,5], amount 11 输出3 解释11 5 5 1输入coins [2], amount 3 输出-1 我的第一反应很真实看到「最少数量」大脑自动弹出三个词BFSDP背包问题于是立刻写出dp[i] min(dp[i - coin] 1)✅ 对❌ 但不够因为这题真正的坑在于amount 很大coins 很小不能只靠直觉 解法一BFS最直观把问题看成一张图节点金额0 ~ amount边减去一枚硬币目标从0 → amount的最少步数class Solution { public int coinChange(int[] coins, int amount) { QueueInteger queue new LinkedList(); boolean[] visited new boolean[amount 1]; queue.offer(0); visited[0] true; int steps 0; while (!queue.isEmpty()) { int size queue.size(); for (int i 0; i size; i) { int cur queue.poll(); for (int coin : coins) { int next cur coin; if (next amount) return steps 1; if (next amount) continue; if (!visited[next]) { visited[next] true; queue.offer(next); } } } steps; } return -1; } }✅ 思路极其清晰❌ 实际性能一般队列 访问数组 解法二DP面试必写状态定义dp[i] 凑出金额 i 所需的最少硬币数状态转移dp[i] min(dp[i - coin] 1)代码面试首选 ✅class Solution { public int coinChange(int[] coins, int amount) { int[] dp new int[amount 1]; Arrays.fill(dp, amount 1); dp[0] 0; for (int i 1; i amount; i) { for (int coin : coins) { if (i coin) { dp[i] Math.min(dp[i], dp[i - coin] 1); } } } return dp[amount] amount ? -1 : dp[amount]; } }复杂度指标结果时间复杂度O(amount × len(coins))空间复杂度O(amount)✅ 稳✅ 好写✅ 面试官最爱 解法三贪心不行重要认知很多人会问能不能用贪心每次选最大面值结论不行 ❌反例coins [1, 3, 4, 5] amount 7贪心5 1 1 3 枚最优3 4 2 枚零钱兑换 ≠ 贪心 我学到的东西这题让我彻底想通了一件事问题本质完全平方数数学定理零钱兑换无环最短路径跳跃游戏 II必须跳的决策你不是在枚举答案而是在剪掉不可能的路。⚠️ 易错点总结误区正确做法用贪心老老实实 DPdp 初值设为 0应设为 INF忘记判断无解最后检查 dp[amount]BFS 忘记 visited会超时 一句话总结零钱兑换 完全背包 最少数量 最短路径 面试收尾建议直接背“这道题我可以用三种思路来看第一种是 BFS把它当成最短路径问题第二种是动态规划时间复杂度 O(amount × coins)第三种是证明贪心不可行说明为什么必须用 DP。实际面试中我会先写 DP 保底再讨论 BFS 和优化空间。”

相关文章:

从能算到秒杀:零钱兑换与「最少硬币」的数学真相

如果说 279. 完全平方数​ 是在考你:👉 最少用几个平方数拼出一个数那 322. 零钱兑换​ 就是它的「现实版」:👉 最少用几枚硬币凑出一个金额这也是我第一次真正明白一句话:所有「最少数量」的问题,本质都是…...

如何5分钟快速集成PinLockView到你的Android应用:终极指南 [特殊字符]

如何5分钟快速集成PinLockView到你的Android应用:终极指南 🚀 【免费下载链接】PinLockView A clean, minimal, highly customizable pin lock view for Android 项目地址: https://gitcode.com/gh_mirrors/pi/PinLockView PinLockView 是一个专为…...

G-Helper:释放华硕笔记本性能的免费开源轻量控制神器

G-Helper:释放华硕笔记本性能的免费开源轻量控制神器 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar, ProArt, Vivobook, Zenbook, Exp…...

5个理由让你立即尝试ImStudio:实时GUI布局设计器

5个理由让你立即尝试ImStudio:实时GUI布局设计器 【免费下载链接】ImStudio GUI layout designer for Dear ImGui 项目地址: https://gitcode.com/gh_mirrors/im/ImStudio ImStudio是一个基于Dear ImGui的实时GUI布局设计器,专为游戏开发者和应用…...

Atomic-Server API完全参考:开发者必备的接口文档指南

Atomic-Server API完全参考:开发者必备的接口文档指南 【免费下载链接】atomic-server An open source headless CMS / real-time database. Powerful table editor, full-text search, and SDKs for JS / React / Svelte. 项目地址: https://gitcode.com/gh_mirr…...

Vue3——defineOptions和defineModel

1.出现背景2.defineOptions2.1 作用当使用setup语法糖后,它把很多东西都隐藏起来了,让你不需要手动写 export default(Vue2) 或者 setup() 原生函数,但是其它组件选项对象需要 export default 存在才能添加。defineOptions用于在单文件组件&a…...

终极Pandoc文档转换指南:5分钟掌握40+格式互转神器

终极Pandoc文档转换指南:5分钟掌握40格式互转神器 【免费下载链接】pandoc Universal markup converter 项目地址: https://gitcode.com/gh_mirrors/pa/pandoc 还在为不同文档格式之间的转换而烦恼吗?学术论文需要LaTeX排版,技术文档要…...

掌握Manim数学动画引擎:从零到一的完整攻略

掌握Manim数学动画引擎:从零到一的完整攻略 【免费下载链接】manim Animation engine for explanatory math videos 项目地址: https://gitcode.com/GitHub_Trending/ma/manim Manim是一款专为数学可视化设计的强大动画引擎,能够通过编程方式创建…...

当99%的作业都是AI写的,大学还剩什么?这届“AI原住民”毕业生的答案亮了!

前言2023年,当ChatGPT横空出世,全球大学生集体迎来一个“作弊神器”——但很快大家发现,它根本不是用来抄作业的,而是重新定义了“学习”本身。这届毕业生有点特殊:他们是人类历史上第一批和生成式AI一起长大的学生&am…...

大模型训练师的炼丹之道 (3)-更高级训练,如何把大规模知识“刻”入模型

前言 在《炼丹之道》前两篇中,我们完成了从基础认知到身份重塑的入门仪式——当模型脱口而出“我是威震天”时,你已触摸到微调的魔法边缘。但那终究只是角色扮演的雏形,真正的炼丹术,在于将冰冷、精确的商业事实熔铸为模型的“肌…...

5分钟解锁AI智能助手:Qwen-Agent模型配置完全指南

5分钟解锁AI智能助手:Qwen-Agent模型配置完全指南 【免费下载链接】Qwen-Agent Agent framework and applications built upon Qwen>3.0, featuring Function Calling, MCP, Code Interpreter, RAG, Chrome extension, etc. 项目地址: https://gitcode.com/Git…...

城市交通气候适应:从生物滞留池到透水铺装的工程实践

1. 项目概述:当城市交通遇上极端天气干了十几年市政工程,我越来越觉得,现在的城市交通系统就像个“玻璃人”——看着钢筋铁骨,实则脆弱得很。一场暴雨,主干道就能变成“主干河”;连续高温,沥青路…...

终极网页资源下载神器:ResourcesSaverExt完整操作指南

终极网页资源下载神器:ResourcesSaverExt完整操作指南 【免费下载链接】ResourcesSaverExt Chrome Extension for one click downloading all resources files and keeping folder structures. 项目地址: https://gitcode.com/gh_mirrors/re/ResourcesSaverExt …...

SillyTavern终极指南:3步搭建你的AI聊天室,轻松管理所有AI模型

SillyTavern终极指南:3步搭建你的AI聊天室,轻松管理所有AI模型 【免费下载链接】SillyTavern LLM Frontend for Power Users. 项目地址: https://gitcode.com/GitHub_Trending/si/SillyTavern 你是否曾想过拥有一个统一的界面来管理所有AI聊天模型…...

Balena Etcher:3步搞定镜像烧录,告别传统工具烦恼

Balena Etcher:3步搞定镜像烧录,告别传统工具烦恼 【免费下载链接】etcher Flash OS images to SD cards & USB drives, safely and easily. 项目地址: https://gitcode.com/GitHub_Trending/et/etcher 你是否曾为制作启动盘而烦恼&#xff1…...

ARM处理器命名后缀解析与技术演进

1. ARM处理器命名后缀解析:从TDMI-S到T2F-S的技术演进作为一名长期从事嵌入式开发的工程师,我经常需要查阅ARM处理器的技术文档。初次接触ARM7TDMI-S、ARM926EJ-S这类命名时,那些神秘的字母后缀确实让人困惑。今天我们就来彻底拆解这些命名背…...

Shader Graph边缘光原理与实战:从菲涅尔效应到世界空间法线

1. 为什么边缘光不是“加个描边”那么简单——从美术需求到Shader本质的错位“给模型加个边缘光”,听起来像Unity编辑器里拖个组件、点几下鼠标就能搞定的事。我第一次接到这个需求时,美术同学在评审会上甩出一张《原神》角色截图,指着雷电将…...

ARM架构中APB外设与External PPB空间部署解析

1. APB系统外设与External PPB空间的关系解析在嵌入式系统设计中,APB(Advanced Peripheral Bus)作为ARM架构中广泛使用的低速外设总线,其常规部署位置通常位于SoC内部。但近年来,随着异构计算和模块化设计的普及,将APB外设放置在E…...

3分钟掌握AlwaysOnTop:让关键窗口始终置顶的Windows神器

3分钟掌握AlwaysOnTop:让关键窗口始终置顶的Windows神器 【免费下载链接】AlwaysOnTop Make a Windows application always run on top 项目地址: https://gitcode.com/gh_mirrors/al/AlwaysOnTop 你是否曾经在编写代码时需要同时查看API文档,却被…...

量子Krylov子空间算法与经典阴影技术解析

1. 量子Krylov子空间算法原理与实现量子Krylov子空间算法是当前NISQ(含噪声中等规模量子)时代最具前景的量子-经典混合算法之一。其核心思想是通过构造一组Krylov基矢{|ψₖ⟩} {|ψ₀⟩, H|ψ₀⟩, H|ψ₀⟩,..., H^(d-1)|ψ₀⟩},将高维希…...

《Sysinternals实战指南》ZoomIt 学习笔记(11.12):LiveZoom 实时放大——无闪屏放大与多屏演示技巧

🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...

《Sysinternals实战指南》ZoomIt 学习笔记(11.11):休息计时器与演讲节奏控制——倒计时、番茄钟与现场掌控力

🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...

《Sysinternals实战指南》ZoomIt 学习笔记(11.10):键入模式——在桌面上直接打字讲解的最佳实践

🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...

《Sysinternals实战指南》ZoomIt 学习笔记(11.9):绘图模式——演示时“手写板”:标注、圈画、临时白板

🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》 《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...

catlass - 让算子开发像搭积木一样简单

昇腾CANN的算子开发,以前是个"体力活"——每个算子都要手写 C 代码,调内存、调流水、调同步,写对了算你厉害,写错了调试三天。 catlass 要解决的就是这个问题:把算子开发从"手写汇编"变成"搭…...

如何高效下载QQ音乐资源:5个简单步骤掌握res-downloader嗅探技术

如何高效下载QQ音乐资源:5个简单步骤掌握res-downloader嗅探技术 【免费下载链接】res-downloader 视频号、小程序、抖音、快手、小红书、直播流、m3u8、酷狗、QQ音乐等常见网络资源下载! 项目地址: https://gitcode.com/GitHub_Trending/re/res-downloader …...

终极指南:如何用OpenPilot为您的爱车升级智能驾驶系统

终极指南:如何用OpenPilot为您的爱车升级智能驾驶系统 【免费下载链接】openpilot openpilot is an operating system for robotics. Currently, it upgrades the driver assistance system on 300 supported cars. 项目地址: https://gitcode.com/GitHub_Trendin…...

你的 FlashAttention 真的在跑吗?几个简单方法确认

之前有个朋友在昇腾 NPU 上部署模型,按文档开了 --enable-flash-attn,跑起来也没报错。但他总觉得延迟不对——跟之前没开的时候差不多。他问我:怎么确认 FlashAttention 真的生效了?不会是静默降级了吧? 这个问题问得…...

nodejs后端服务如何接入taotoken实现异步调用多模型对话能力

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 Node.js 后端服务如何接入 Taotoken 实现异步调用多模型对话能力 1. 准备工作:获取 API Key 与模型 ID 在开始编写代码…...

【Feed 高并发架构实战】:雪花 ID + 三级缓存 + 计数旁路设计详解

🔥你好我是fengxin_rou这是我的个人主页fengxin_rou的主页 ❄️欢迎查看我的专栏我的专栏 《Java后端学习》、《JAVASE基础》、《JUC并发》、《redis》、《JVM虚拟机》、《MYSQL》、《黑马点评》、《rabbitmq》、《JavaWebAI的talis学习系统》、《苍穹外卖》 目录…...