【c++刷题笔记-动态规划】day38: 322. 零钱兑换 、 279.完全平方数 、139.单词拆分

322. 零钱兑换 - 力扣(LeetCode)

思路:完全背包,初始化为最大背包容量,当背包为0的时候有0枚硬币

重点:dp[i-coins[j]]+1,统计个数

class Solution {
public:int coinChange(vector<int>& coins, int amount) {int n=coins.size();vector<int>dp(amount+1,amount+1);//设置背包初始值dp[0]=0;//当背包为0的时候有0枚硬币for(int i=1;i<=amount;i++){//遍历背包for(int j=0;j<n;j++){//遍历物品if(coins[j]<=i)//物品重量小于等于背包容量dp[i]=min(dp[i],dp[i-coins[j]]+1);}}return dp[amount]>amount?-1:dp[amount];}
};

279. 完全平方数 - 力扣(LeetCode)

思路:完全背包,n是背包,从1开始的平方数是物品。先遍历背包再遍历物品

重点:dp[i-j*j]+1

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

139. 单词拆分 - 力扣(LeetCode)

思路:利用哈希表存放字典的单词,dp[i]表示字符串长度为i时由字典中的一个或者多个单词组成。

重点:遍历每一个区间的子串。如果当前下标j开始的子串不能与字典匹配则跳过

class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {int n=s.size();//把所有单词放入哈希表中unordered_set<string>hash(wordDict.begin(),wordDict.end());vector<bool>dp(n+1,false);dp[0]=true;//初始化dp[0]数组为true,基于此递推for(int i=1;i<=n;i++){//遍历背包for(int j=0;j<i;j++){//遍历物品string word=s.substr(j,i-j);//遍历从j到i区间的所有子串if(hash.find(word)!=hash.end()&&dp[j]){//如果当前开始的子串不能与字典匹配则跳过dp[i]=true;}}}return dp[n];}
};

总结

遇到求数量题可以尝试使用递推公式为dp[j-weight[i]]+1

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/46454.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenCV解决验证码(数字和字母)识别(Python)

文章目录 前言一、准备验证码图片 前言 OpenCV是一个基于Apache2.0许可&#xff08;开源&#xff09;发行的跨平台计算机视觉和机器学习软件库。它支持Windows、Linux、Mac OS、Android和iOS等多个操作系统&#xff0c;提供了丰富的图像处理和计算机视觉功能&#xff0c;包括但…

WINUI——实现点在直线上随意移动

开发环境 VS2022 .net core6 需求 需要在一条直线上可随意移动一个点&#xff0c;这个点一定要在这条直线上&#xff0c;不可移出直线。也就是说A点到B点的直线就是这个点的移动范围。 需求深入分析 这个需求看上去&#xff0c;感觉完全可以使用Slider实现&#xff0c;因为…

RPC与服务的注册发现

文章目录 1. 什么是远程过程调用(RPC)?2. RPC的流程3. RPC实践4. RPC与REST的区别4.1 RPC与REST的相似之处4.2 RPC与REST的架构原则4.3 RPC与REST的主要区别 5. RPC与服务发现5.1 以zookeeper为服务注册中心5.2 以etcd为服务注册中心 6. 小结参考 1. 什么是远程过程调用(RPC)?…

(自用)网络编程

OSI七层协议模型 (open system interconnection) 应用层————为应用数据提供服务 表示层————数据格式转化&#xff0c;数据加密 会话层————建立、维护和管理会话 传输层————建立、维护和管理端到端的链接&#xff0c;控制数据传输的方式 网络层————数据…

昇思25天学习打卡营第19天|基于MobileNetv2的垃圾分类

国内城市生活垃圾一般分类为以下四大类&#xff1a; 可回收垃圾&#xff1a;主要包括废纸、塑料、玻璃、金属和布料五大类。废纸如报纸、期刊、图书、包装纸等&#xff1b;塑料如各种塑料袋、塑料包装物、一次性塑料餐盒等&#xff1b;玻璃如玻璃瓶、碎玻璃片等&#xff1b;金…

Windows图形界面(GUI)-DLG-C/C++ - 图形界面程序结构

公开视频 -> 链接点击跳转公开课程博客首页 -> ​​​​​​链接点击跳转博客主页 目录 Windows图形界面程序结构 Windows 程序结构 窗口类和窗口过程函数 创建和显示窗口 消息循环和消息处理机制 Windows图形界面程序结构 Windows 程序结构 WinMain 函数WinMain …

【2024最新】C++读写优化超详细解析(cin优化+普通快读+fread)_输入输出优化_快读快写_算法竞赛

在算法竞赛中&#xff0c;读入速度和输出速度一直是卡常的重要手段。也有不少人经历过被题目卡 cin 的情况。今天我给大家介绍一下算法竞赛中常用的读写方法及其优化。 声明&#xff1a;大部分情况下&#xff0c;只用读入优化就行。对于输出量大的题目再考虑使用输出优化。 一…

Base64实现传输图片

1. Base64简介 Base64是一种基于64个可打印字符来表示二进制数据的表示方法。通常用于在URL、Cookie和邮件等场景中&#xff0c;将二进制数据转换为字符串形式进行传输。 代码实现 public class ImageUtils {/*** 得到图片的Base64编码* param imagePath 图片路径* return …

手机删除的文件能恢复吗?删除不等于永别,3个技巧助你找回

安卓手机中的文件&#xff0c;就像是数字世界里的繁星&#xff0c;记录着我们的点点滴滴。然而&#xff0c;有时我们可能会不小心删除了某些重要的文件&#xff0c;让我们感到惋惜和困惑。删除的文件能恢复吗&#xff1f;别担心&#xff0c;删除并不等于永别&#xff0c;我们也…

Maven报错 NullPointerException as JavaCompiler.readSourceFile

1. 报错详情 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project xxx-web: Fatal error compiling: CompilerException: NullPointerException -> [Help 1] org.apache.maven.lifecycle.Lifecycl…

CentOS 停服后,服务器 OS 路在何方?

2024 年 6 月 30 日&#xff0c;CentOS Linux 7 终止其生命周期&#xff08;EOL&#xff09;&#xff0c;至此 CentOS 全系列版本也已停止维护&#xff0c;属于 CentOS 的时代彻底终结。CentOS 停止维护后&#xff0c;用户将无法获得包括问题修复和功能更新在内的任何软件维护和…

小程序里面使用vant ui中的vant-field组件,如何使得输入框自动获取焦点

//.wxml <van-fieldmodel:value"{{ userName }}"placeholder"请输入学号"focus"{{focusUserName}}"/>// .js this.setData({focusUserName: true});vant-field

LLMs之RAG:GraphRAG(本质是名词Knowledge Graph/Microsoft微软发布)的简介、安装和使用方法、案例应用之详细攻略

LLMs之RAG&#xff1a;GraphRAG(本质是名词Knowledge Graph/Microsoft微软发布)的简介、安装和使用方法、案例应用之详细攻略 导读&#xff1a;2024年7月3日&#xff0c;微软正式开源发布GraphRAG。GraphRAG可以提高大型语言模型在私有数据集上的推理能力。 背景痛点&#xff1…

MSVC2017+Qt 打包

在环境变量下配置好 QT 和 MSVC 的路径 相关搜索&#xff1a; 找不到msvcp140.dll 1.搜索 Qt 选择在编译器路径下打开 2. Windeployqt 生成打包&#xff0c;正常情况下生成 VC 相关package&#xff0c; 即 msvcp140.dll 等MSVC 相关 但是lz尝试没有生成 解决办法 先将生成…

数据库作业d8

要求&#xff1a; 一备份 1 mysqldump -u root -p booksDB > booksDB_all_tables.sql 2 mysqldump -u root -p booksDB books > booksDB_books_table.sql 3 mysqldump -u root -p --databases booksDB test > booksDB_and_test_databases.sql 4 mysql -u roo…

MySQL 中的几种锁

MySQL 中的锁 #按锁粒度如何划分? 按锁粒度划分的话&#xff0c;MySQL 的锁有&#xff1a; 表锁&#xff1a;开销小&#xff0c;加锁快&#xff1b;锁定力度大&#xff0c;发生锁冲突概率高&#xff0c;并发度最低;不会出现死锁。行锁&#xff1a;开销大&#xff0c;加锁慢…

电脑压缩软件哪个好?WinRAR、7-Zip、Bandizip 还是360压缩

文件压缩软件已成为我们日常工作中不可或缺的一部分&#xff0c;它不仅能够帮助我们节省存储空间&#xff0c;还能提高文件传输效率。本文简鹿办公小编将对四款主流的电脑压缩软件进行对比&#xff0c;它们分别是 WinRAR、7-Zip、Bandizip 和 360 压缩。 一、WinRAR WinRAR 是…

Qt中文个数奇数时出现问号解决

Qt中文个数奇数时出现问号解决 目录 Qt中文个数奇数时出现问号解决问题背景问题场景解决方案 问题背景 最近在开发一个小工具&#xff0c;涉及到一些中文注释自动打印&#xff0c;于是摸索如何把代码里面的中文输出到csv文件中&#xff0c;出现了乱码&#xff0c;按照网上的攻…

vue2-Django3-iframe解决方案,处理安全策略,事件拦截,处理iframe重载等

目录 简介 实现iframe 后端安全策略 通过Ngnix代理实现SAMEORIGIN iframe的事件拦截&#xff0c;自定义处理 iframe的状态保持&#xff08;解决vue中iframe重载&#xff09; 解决方法 简介 Iframe&#xff08;内联框架&#xff09;是一种HTML元素&#xff0c;用于在网页…

Nginx配置缺少导致CSS不起作用

引言 在Web开发中&#xff0c;确保样式表正确加载是前端显示正常工作的关键。然而&#xff0c;有时候即使CSS文件的路径和代码本身没有问题&#xff0c;CSS样式也可能无法正确应用。本文将分享一个常见的问题——Nginx配置缺少导致的CSS不起作用&#xff0c;以及如何解决这个问…