day38|leetcode 322零钱兑换,279.完全平方数,139.单词拆分

ops/2025/2/7 3:24:20/

322. 零钱兑换

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。

计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1

你可以认为每种硬币的数量是无限的。

这题与零钱兑换II的区别在于本题需要返回最小数

动规五部曲:

(1)dp数组的含义:dp[j]代表凑成总金额为j所需的最少的硬币个数

(2)确定递推公式:dp[j-coins[i]]就是凑成j-coins[i]所需的最少的硬币个数,加上coins[i]就是dp[j]即dp[j-coins[i]]+1,由于求的是最小值,所以dp[j]=min(dp[j-coins]+1,dp[j]);

(3)初始化:dp[0]=0,由递推公式可知为了防止0覆盖之后的所有元素,除了dp[0]其他位置都应该初始化为非零数

(4)确定遍历顺序:由于求的是最小值,所以并不需要考虑组合数还是排列数

(5)打印dp数组

class Solution {
public:int coinChange(vector<int>& coins, int amount) {int bagweight = amount;vector<int>dp(bagweight+1,INT_MAX);dp[0]=0;for(int i=0;i<coins.size();i++)//先遍历物品{for(int j=coins[i];j<=bagweight;j++){if(dp[j-coins[i]]!=INT_MAX)//如果等于初始值就跳过dp[j]=min(dp[j-coins[i]]+1,dp[j]);}}if(dp[bagweight]==INT_MAX)return -1;return dp[bagweight];}
};

279. 完全平方数

给你一个整数 n ,返回 和为 n 的完全平方数的最少数量

完全平方数 是一个整数,其值等于另一个整数的平方;换句话说,其值等于一个整数自乘的积。例如,14916 都是完全平方数,而 311 不是。

输入:n = 12
输出:3 
解释:12 = 4 + 4 + 4

题目分析:背包容量就是n,完全平方数就是物品

完全平方数就是i*i

动规五部曲:

(1)dp[j]含义:和为j的完全平方数的最少数量

(2)确定递推公式:dp[j]=min(dp[j-i*i]+1,dp[j]);

(3)初始化:dp[0]=0,为了防止后续的值被覆盖,除了dp[0]其他都应该初始化为INT_MAX

(4)确定遍历顺序:求最小值不强调组合数还是排列数

(5)打印dp数组

class Solution {
public:int numSquares(int n) {int bagweight = n;vector<int>dp(bagweight+1,INT_MAX);dp[0]=0;for(int j=0;j<=n;j++)//先遍历背包{for(int i=1;i*i<=j;i++){dp[j]=min(dp[j-i*i]+1,dp[j]);}}return dp[bagweight];}
};

139. 单词拆分

给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true

注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。

示例 1:

输入: s = "leetcode", wordDict = ["leet", "code"]
输出: true
解释: 返回 true 因为 "leetcode" 可以由 "leet" 和 "code" 拼接成。

题意分析:字符串是s,单词是物品

动规五部曲:

(1)dp[j]含义:dp[j] : 字符串长度为i的话,dp[j]为true,表示可以拆分为一个或多个在字典中出现的单词

(2)确定递推公式:如果确定dp[j] 是true,且 [j, i] 这个区间的子串出现在字典里,那么dp[i]一定是true。(j < i )。

所以递推公式是 if([j, i] 这个区间的子串出现在字典里 && dp[j]是true) 那么 dp[i] = true。

(3)初始化:由递推公式可知,dp[0]决定了后续的,所以dp[0]=true,其他设为false

(4)确定遍历顺序:先遍历背包后遍历物品,因为s="apple pen apple" 时s=apple+pen+apple,其他顺序不是s,所以强调顺序,也就是属于排列数

(5)打印dp数组

class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {unordered_set<string>wordSet(wordDict.begin(),wordDict.end());vector<bool>dp(s.size()+1,false);dp[0]=true;for(int j=1;j<=s.size();j++)//先遍历背包{for(int i=0;i<j;i++)//再遍历物品{string str = s.substr(i,j-i);if(wordSet.find(str)!=wordSet.end() && dp[i]){dp[j]=true;}}}return dp[s.size()];}
};


http://www.ppmy.cn/ops/156327.html

相关文章

我的鸿蒙学习之旅:探索万物互联的新宇宙

在科技飞速发展的今天&#xff0c;操作系统领域的创新层出不穷。华为鸿蒙系统的出现&#xff0c;犹如一颗璀璨的新星&#xff0c;照亮了万物互联的未来之路。怀着对新技术的好奇与渴望&#xff0c;我踏上了学习鸿蒙的征程&#xff0c;这段经历充满了挑战与惊喜&#xff0c;也让…

SQLAlchemy通用分页函数实现:支持搜索、排序和动态页码导航

SQLAlchemy通用分页函数实现&#xff1a;支持搜索、排序和动态页码导航 在Web应用开发中&#xff0c;分页功能是一个非常常见的需求。本文将介绍一个基于SQLAlchemy的通用分页函数实现&#xff0c;该实现不仅支持基本的分页功能&#xff0c;还包含了搜索、排序以及动态页码导航…

SpringSecurity密码编码器:使用BCrypt算法加密、自定义密码编码器

1、Spring Security 密码编码器 Spring Security 作为一个功能完备的安全性框架,一方面提供用于完成加密操作的 PasswordEncoder 组件,另一方面提供一个可以在应用程序中独立使用的密码模块。 1.1 PasswordEncoder 抽象接口 在 Spring Security 中,PasswordEncoder 接口代…

为AI聊天工具添加一个知识系统 之78 详细设计之19 正则表达式 之6

本文要点 要点 本项目设计的正则表达式 是一个 动态正则匹配框架。它是一个谓词系统&#xff1a;谓词 是运动&#xff0c;主语是“维度”&#xff0c;表语是 语言处理。主语的一个 双动结构。 Reg三大功能 语法验证、语义检查和 语用检验&#xff0c;三者 &#xff1a;语义约…

高阶开发基础——快速入门C++并发编程6——大作业:实现一个超级迷你的线程池

目录 实现一个无返回的线程池 完全代码实现 Reference 实现一个无返回的线程池 实现一个简单的线程池非常简单&#xff0c;我们首先聊一聊线程池的定义&#xff1a; 线程池&#xff08;Thread Pool&#xff09; 是一种并发编程的设计模式&#xff0c;用于管理和复用多个线程…

2024华为OD机试E卷-数大雁-(Python)

2024华为OD机试最新E卷题库-(C卷+D卷+E卷)-(JAVA、Python、C++) 目录 题目描述 输入描述 输出描述 用例1 用例2 用例3 用例4 考点 题目解析 代码 题目描述 一群大雁往南飞,给定一个字符串记录地面上的游客听到的大雁叫声,请给出叫声最少由几只大雁发出。 具体的…

CVPR | CNN融合注意力机制,芜湖起飞!

**标题&#xff1a;**On the Integration of Self-Attention and Convolution **论文链接&#xff1a;**https://arxiv.org/pdf/2111.14556 **代码链接&#xff1a;**https://github.com/LeapLabTHU/ACmix 创新点 1. 揭示卷积和自注意力的内在联系 文章通过重新分解卷积和自…

C++ Primer 标准库vector

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…