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

两道算法练习

力扣322零钱兑换

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

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

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

示例 1:

输入: coins = [1, 2, 5], amount = 11
输出: 3
解释: 11 = 5 + 5 + 1

示例 2:

输入: coins = [2], amount = 3
输出: -1

示例 3:

输入: coins = [1], amount = 0
输出: 0

提示:

  • 1 <= coins.length <= 12
  • 1 <= coins[i] <= 231 - 1
  • 0 <= amount <= 104

分析思路

  • 分析子问题,当所有的子问题都是最优的时候总问题也就达到了最优。
  • 分析最终状态,以示例1为例子:在选到5的时候刚好满足金额等于amount同时数量最优
  • 分析去掉最后一个问题的状态:
    它的子问题也就是:用最少得硬币数凑出 amount - 5
  • 可以发现这个问题可以像递归搜索树一样进行拆分
  • 又继续分析去掉倒数第二个问题的状态。
    那么我们来分析代码:
const int N = 10010;class Solution
{int mem[N];int dfs(vector<int>& coins, int amount){if (mem[amount])return mem[amount];int res = 1e9;if (amount == 0)return 0;if (amount < 0)return 1e9;for (int i = 0; i < coins.size(); i++){if (amount >= coins[i])res = min(res, 1 + dfs(coins, amount - coins[i]));}mem[amount]  = res;return res;}
public:int coinChange(vector<int>& coins, int amount){int n = coins.size();int ans = dfs(coins, amount);return ans == 1e9 ? -1 : ans;}
};
  • 我们的思路就是让它凑出的每一个amount之前的数值都满足最小硬币的需求,那么当它递推到amount的时候,它的每一个子问题都是最优的,那么总问题就是最优的了。
        for (int i = 0; i < coins.size(); i++){if (amount >= coins[i])res = min(res, 1 + dfs(coins, amount - coins[i]));}
  • 我们不断地往下搜索,直到amount被减到0,其中每一个分支都进行了min的处理,所以当从下往上回溯的时候,返回的就是每个分支就小的情况也是每个子问题最优的情况。

  • 所以我们可以这样想dp:
    我们从凑出1块2块3块…知道amount块钱,每一次我们都考虑凑出的硬币数量最少,那么当我们推到amount的时候,不就是最优了吗?

class Solution 
{
public:int coinChange(vector<int>& coins, int amount) {if (amount == 0)return 0;int n = coins.size();vector<int> dp(amount + 1, amount + 1);dp[0] = 0;for (int i = 1; i <= amount; i++){ for (int coin : coins){ if (i >= coin)dp[i] = min(dp[i], dp[i - coin] + 1);}}return dp[amount] > amount ? -1 : dp[amount];    }
};
  • dp数组中的每个元素都被初始化为比amount大的数字,我们每次都更新凑得钱数所需硬币的最小值,从1凑到amount,这样到了amount的时候,就是最优的答案了

leetcode 413

如果一个数列 至少有三个元素 ,并且任意两个相邻元素之差相同,则称该数列为等差数列。

  • 例如,[1,3,5,7,9][7,7,7,7] 和 [3,-1,-5,-9] 都是等差数列。

给你一个整数数组 nums ,返回数组 nums 中所有为等差数组的 子数组 个数。

子数组 是数组中的一个连续序列。

示例 1:

输入: nums = [1,2,3,4]
输出: 3
解释: nums 中有三个子等差数组:[1, 2, 3]、[2, 3, 4] 和 [1,2,3,4] 自身。

示例 2:

输入: nums = [1]
输出: 0

提示:

  • 1 <= nums.length <= 5000
  • -1000 <= nums[i] <= 1000

1.
重述问题:找出数组中所有等差子数组的数量包括它本身
2.
最后一步

  • 以第 i 个元素结尾的等差子数组数目,取决于当前差值是否与前一个差值相等。

  • 如果相等,则以 i 结尾的数目等于以 i-1 结尾的数目加 1
    3.
    去掉最后一步,是否能划分出子问题:

  1. 子问题划分

    • 如果当前差值与前一个差值相等,则 dp[i] = dp[i-1] + 1

    • 否则,dp[i] = 0

示例 1:

输入:nums = [1, 2, 3, 4]

我们需要找出所有长度至少为 3 的连续子数组,且这些子数组是等差数列。

  • 子数组 [1, 2, 3]:差值为 1,是等差数列。

  • 子数组 [2, 3, 4]:差值为 1,是等差数列。

  • 子数组 [1, 2, 3, 4]:差值为 1,是等差数列。

总共有 3 个等差子数组。


示例 2:

输入:nums = [1, 3, 5, 7, 9]

  • 子数组 [1, 3, 5]:差值为 2,是等差数列。

  • 子数组 [3, 5, 7]:差值为 2,是等差数列。

  • 子数组 [5, 7, 9]:差值为 2,是等差数列。

  • 子数组 [1, 3, 5, 7]:差值为 2,是等差数列。

  • 子数组 [3, 5, 7, 9]:差值为 2,是等差数列。

  • 子数组 [1, 3, 5, 7, 9]:差值为 2,是等差数列。

总共有 6 个等差子数组。


表格分析

我们可以通过表格来记录以每个位置结尾的等差子数组的个数。假设 dp[i] 表示以第 i 个元素结尾的等差子数组的个数。

示例 1:nums = [1, 2, 3, 4]
索引 (i)元素值 (nums[i])差值 (nums[i] - nums[i-1])前一个差值 (nums[i-1] - nums[i-2])dp[i](以 i 结尾的等差子数组个数)解释
01--0长度不足 3,无法形成等差子数组。
121-0长度不足 3,无法形成等差子数组。
23111差值相等,形成一个新的等差子数组 [1, 2, 3]
34112差值相等,形成一个新的等差子数组 [2, 3, 4],并扩展 [1, 2, 3, 4]

最终结果:dp[2] + dp[3] = 1 + 2 = 3


示例 2:nums = [1, 3, 5, 7, 9]
索引 (i)元素值 (nums[i])差值 (nums[i] - nums[i-1])前一个差值 (nums[i-1] - nums[i-2])dp[i](以 i 结尾的等差子数组个数)解释
01--0长度不足 3,无法形成等差子数组。
132-0长度不足 3,无法形成等差子数组。
25221差值相等,形成一个新的等差子数组 [1, 3, 5]
37222差值相等,形成一个新的等差子数组 [3, 5, 7],并扩展 [1, 3, 5, 7]
49223差值相等,形成一个新的等差子数组 [5, 7, 9],并扩展 [3, 5, 7, 9] 和 [1, 3, 5, 7, 9]

最终结果:dp[2] + dp[3] + dp[4] = 1 + 2 + 3 = 6


if (diff == prev_diff) 
{return helper(i-1, nums) + 1;
} 
else 
{return 0;
}

举例说明

示例:nums = [1, 2, 3, 4]
  1. 当 i = 2 时

    • 当前元素:nums[2] = 3

    • 差值:diff = nums[2] - nums[1] = 3 - 2 = 1

    • 前一个差值:prev_diff = nums[1] - nums[0] = 2 - 1 = 1

    • 判断:diff == prev_diff 成立。

    • 递归调用:helper(1, nums),由于 i = 1 不满足条件,返回 0。

    • 结果:helper(2, nums) = helper(1, nums) + 1 = 0 + 1 = 1

      • 表示以 nums[2] 结尾的等差子数组有 1 个,即 [1, 2, 3]
  2. 当 i = 3 时

    • 当前元素:nums[3] = 4

    • 差值:diff = nums[3] - nums[2] = 4 - 3 = 1

    • 前一个差值:prev_diff = nums[2] - nums[1] = 3 - 2 = 1

    • 判断:diff == prev_diff 成立。

    • 递归调用:helper(2, nums) = 1

    • 结果:helper(3, nums) = helper(2, nums) + 1 = 1 + 1 = 2

      • 表示以 nums[3] 结尾的等差子数组有 2 个:

        • [2, 3, 4]

        • [1, 2, 3, 4]

const int N = 10010;
class Solution
{public://x表示当前以nums[x]为结尾的数组int dfs(int x, vector<int>& nums){if (x < 2)return 0;if (mem[x])return mem[x];int diff = nums[x] - nums[x - 1];int prv_diff = nums[x - 1] - nums[x - 2];if (diff == prv_diff){return mem[x] = dfs(x - 1, nums) + 1;}else{return 0;}}int mem[N];int numberOfArithmeticSlices(vector<int> &nums){int n = nums.size();if (nums.size() < 3)return 0;// vector<int> dp(n, 0);int res = 0;int prev = 0;// for (int i = 2; i < nums.size(); i++)// {//     res += dfs(i, nums);// }// return res;for (int i = 2; i < nums.size(); i++){if (nums[i] - nums[i - 1] == nums[i - 1]- nums[i - 2]){// dp[i] = dp[i - 1] + 1;prev = prev + 1;res += prev;}}return prev;}
};

相关文章:

两道算法练习

力扣322零钱兑换 给你一个整数数组 coins &#xff0c;表示不同面额的硬币&#xff1b;以及一个整数 amount &#xff0c;表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额&#xff0c;返回 -1 。 你可以认为每种硬币的…...

利用 Python 爬虫进行跨境电商数据采集

1 引言2 代理IP的优势3 获取代理IP账号4 爬取实战案例---&#xff08;某电商网站爬取&#xff09;4.1 网站分析4.2 编写代码4.3 优化代码 5 总结 1 引言 在数字化时代&#xff0c;数据作为核心资源蕴含重要价值&#xff0c;网络爬虫成为企业洞察市场趋势、学术研究探索未知领域…...

设计模式--spring中用到的设计模式

一、单例模式&#xff08;Singleton Pattern&#xff09; 定义&#xff1a;确保一个类只有一个实例&#xff0c;并提供全局访问点 Spring中的应用&#xff1a;Spring默认将Bean配置为单例模式 案例&#xff1a; Component public class MySingletonBean {// Spring 默认将其…...

Qt控件中函数指针使用的最终版本,使用std::function

代码&#xff1a; class MyWidget : public QWidget { public:std::function<void(QResizeEvent* event)> pf_resizeEvent 0; protected:inline void resizeEvent(QResizeEvent* event) override {if (pf_resizeEvent ! 0)pf_resizeEvent(event);} };int main(int arg…...

Java中的泛型类 --为集合的学习做准备

学习目标 ● 掌握在集合中正确使用泛型 ● 了解泛型类、泛型接口、泛型方法 ● 了解泛型上下限 ● 了解基本的使用场景 1.有关泛型 1.1泛型的概念 泛型&#xff08;Generics&#xff09;是Java中引入的参数化类型机制&#xff0c;允许在定义类、接口或方法时使用类型参数&a…...

6.6.6 嵌入式SQL

文章目录 2个核心问题识别SQL语句主语言和SQL通信完整导图 2个核心问题 SQL语句嵌入高级语言需要解决的2个核心问题是&#xff1a;如何识别嵌入语句&#xff1f;如何让主语言&#xff08;比如C,C语言&#xff09;和SQL通信&#xff1f; 识别SQL语句 为了识别主语言中嵌入的SQL…...

基于C#的CANoe CLR Adapter开发指南

一、引言 CANoe 是一款广泛应用于汽车电子开发和测试的工具&#xff0c;它支持多种编程接口&#xff0c;方便开发者进行自定义扩展。CANoe CLR Adapter 允许我们使用 C# 语言与 CANoe 进行交互&#xff0c;充分利用 C# 的强大功能和丰富的类库。本文将详细介绍如何基于 C# 进行…...

【Qt】MVC设计模式

目录 一、搭建MVC框架 二、创建数据库连接单例类SingleDB 三、数据库业务操作类model设计 四、control层&#xff0c;关于model管理类设计 五、view层即为窗口UI类 一、搭建MVC框架 里面的bin、lib、database文件夹以及sqlite3.h与工程后缀为.pro文件的配置与上次发的文章…...

【手撕算法】支持向量机(SVM)从入门到实战:数学推导与核技巧揭秘

摘要 支持向量机&#xff08;SVM&#xff09;是机器学习中的经典算法&#xff01;本文将深入解析最大间隔分类原理&#xff0c;手撕对偶问题推导过程&#xff0c;并实战实现非线性分类与图像识别。文中附《统计学习公式手册》及SVM调参指南&#xff0c;助力你掌握这一核心算法…...

JAVA面试常见题_基础部分_Dubbo面试题(上)

Dubbo 支持哪些协议&#xff0c;每种协议的应用场景&#xff0c;优缺点&#xff1f; • dubbo&#xff1a; 单一长连接和 NIO 异步通讯&#xff0c;适合大并发小数据量的服务调用&#xff0c;以及消费者远大于提供者。传输协议 TCP&#xff0c;异步&#xff0c;Hessian 序列化…...

CSS—隐藏元素:1分钟掌握与使用隐藏元素的方法

个人博客&#xff1a;haichenyi.com。感谢关注 1. 目录 1–目录2–display:none3–visibility: hidden4–opacity: 05–position: absolute;与 left: -9999px;6–z-index 和 position7–clip-path: circle(0%) 2. display:none 标签会挂载在html中&#xff0c;但是不会在页面上…...

二、双指针——5. 移动零

二、双指针——5. 移动零 题目描述示例示例1&#xff1a;示例2&#xff1a; 思路代码 题目描述 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操…...

论文笔记-NeurIPS2017-DropoutNet

论文笔记-NeurIPS2017-DropoutNet: Addressing Cold Start in Recommender Systems DropoutNet&#xff1a;解决推荐系统中的冷启动问题摘要1.引言2.前言3.方法3.1模型架构3.2冷启动训练3.3推荐 4.实验4.1实验设置4.2在CiteULike上的实验结果4.2.1 Dropout率的影响4.2.2 实验结…...

php 对接mqtt 完整版本,订阅消息,发送消息

首先打开链接如何在 PHP 项目中使用 MQTT 根据文章让所用依赖安装一下&#xff1a; composer require php-mqtt/client 安装之后弄一个部署 之后在工具里边可以相应链接上 接下来是代码&#xff1a; /**** 订阅消息* return void* throws \PhpMqtt\Client\Exceptions\Confi…...

谈谈 ES 6.8 到 7.10 的功能变迁(6)- 其他

这是 ES 7.10 相较于 ES 6.8 新增内容的最后一篇&#xff0c;主要涉及算分方法和同义词加载的部分。 自定义算分&#xff1a;script_score 2.0 Elasticsearch 7.0 引入了新一代的函数分数功能&#xff0c;称为 script_score 查询。这一新功能提供了一种更简单、更灵活的方式来…...

【苍穹外卖】问题笔记

【DAY1 】 1.VCS找不到 好吧&#xff0c;发现没安git 接着发现安全模式有问题&#xff0c;点开代码信任此项目 2.导入初始文件&#xff0c;全员爆红 好像没maven&#xff0c;配一个 并在设置里设置好maven 3.启用注解&#xff0c;见新手苍穹 pom.xml改lombok版本为1.1…...

脑机接口SSVEP 信号特征提取技术术语

目录 背景简介 1. 最小能量组合&#xff08;MEC&#xff09;和最大对比组合&#xff08;MCC&#xff09; 2. 典型相关分析&#xff08;CCA&#xff09; 3. 滤波器组CCA&#xff08;FBCCA&#xff09; 4. 二进制子带CCA&#xff08;BsCCA&#xff09; 5. 融合CCA&#xff…...

【Veristand】Veristand 预编写教程目录

很久没有更新&#xff0c;最近打算出一期Veristand教程&#xff0c;暂时目录列成下面这个表格&#xff0c;如果各位有关心的遗漏的点&#xff0c;可以在评论区提问&#xff0c;我后期可以考虑添加进去&#xff0c;但是提前声明&#xff0c;太过小众的点我不会&#xff0c;欢迎各…...

C#光速入门的指南

以下是一份C#快速入门的指南&#xff0c;涵盖了基础语法、面向对象编程、输入输出、异常处理等方面&#xff0c;帮助你快速上手C#。 1. 开发环境搭建 要开始使用C#进行编程&#xff0c;你需要安装开发环境。最常用的是Visual Studio&#xff0c;它提供了丰富的工具和功能&…...

深入探索 STM32 微控制器:从基础到实践

一、引言 在当今的嵌入式系统领域&#xff0c;STM32 系列微控制器凭借其高性能、低功耗、丰富的外设以及广泛的应用场景&#xff0c;成为了众多开发者的首选。无论是在工业控制、智能家居、医疗设备&#xff0c;还是在消费电子等领域&#xff0c;STM32 都展现出了强大的生命力…...

为什么你的模型跨姿态识别总翻车?深入解读VGGFace2数据集的设计哲学与数据清洗实战

为什么你的模型跨姿态识别总翻车&#xff1f;深入解读VGGFace2数据集的设计哲学与数据清洗实战 当算法工程师在深夜调试人脸识别模型时&#xff0c;最令人沮丧的莫过于看到测试结果中那些因姿态变化导致的识别失败案例。一张侧脸照片被系统判定为完全不同的人&#xff0c;这种错…...

Wand-Enhancer:WeMod Pro免费解锁终极指南与完整教程

Wand-Enhancer&#xff1a;WeMod Pro免费解锁终极指南与完整教程 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer Wand-Enhancer是一款开源工具&#xff…...

yz-bijini-cosplay实战体验:一键切换LoRA风格,轻松生成动漫/游戏/国风Cosplay角色

yz-bijini-cosplay实战体验&#xff1a;一键切换LoRA风格&#xff0c;轻松生成动漫/游戏/国风Cosplay角色 你是否曾经为了生成一张理想的Cosplay图片而反复切换模型&#xff0c;每次都要忍受漫长的加载等待&#xff1f;或者因为模型对中文提示词理解不佳&#xff0c;导致生成的…...

intv_ai_mk11入门必看:从健康检查到参数调优的完整使用手册

intv_ai_mk11入门必看&#xff1a;从健康检查到参数调优的完整使用手册 1. 认识intv_ai_mk11 intv_ai_mk11是一个基于Llama架构的中等规模文本生成模型&#xff0c;特别适合处理通用问答、文本改写、解释说明和简短创作等任务。这个模型最大的特点是开箱即用——开发者已经完…...

StructBERT模型加速技巧:利用GPU CUDA进行批量推理优化

StructBERT模型加速技巧&#xff1a;利用GPU CUDA进行批量推理优化 你是不是也遇到过这样的情况&#xff1f;手头有成千上万条文本需要处理&#xff0c;比如做相似度计算、情感分析或者分类&#xff0c;但用模型一条一条地跑&#xff0c;速度慢得让人抓狂。看着GPU的利用率上不…...

Gin框架日志实战:从内置组件到logrus高级集成

1. Gin框架日志系统入门指南 刚接触Gin框架时&#xff0c;很多人都会好奇那些自动打印在控制台的调试信息是从哪来的。其实这就是Gin内置的Logger中间件在发挥作用。当你使用gin.Default()创建路由时&#xff0c;它已经默默帮你加载了两个关键组件&#xff1a;Logger负责请求日…...

PHP跨文件传递参数的8种常见方法

以下是 PHP 中跨文件传递参数的 8 种常见方法&#xff0c;按场景和安全性分类整理&#xff0c;附详细说明和示例代码&#xff1a; 一、超全局变量&#xff08;适合请求间数据共享&#xff09; 1. $_GET / $_POST 用途&#xff1a;通过 URL 或表单提交传递参数&#xff08;客户…...

Meshlab实战指南:从稀疏点云到纹理模型的完整流程

1. Meshlab入门&#xff1a;为什么选择它处理3D重建数据&#xff1f; 第一次接触三维建模的朋友可能会问&#xff1a;Meshlab到底是什么&#xff1f;简单来说&#xff0c;它是一款开源的3D网格处理软件&#xff0c;特别擅长处理从照片重建出来的三维数据。我在实际项目中用它处…...

OpenClaw日志排查助手:千问3.5-9B自动化分析开发日志

OpenClaw日志排查助手&#xff1a;千问3.5-9B自动化分析开发日志 1. 为什么需要日志自动化分析 作为一个长期与代码打交道的开发者&#xff0c;我每天至少有30%的时间花在查看日志上。从服务器报错到本地调试输出&#xff0c;海量的日志信息常常让我陷入"信息过载"…...

3步终极指南:用Docker容器让老旧打印机秒变AirPrint无线打印神器

3步终极指南&#xff1a;用Docker容器让老旧打印机秒变AirPrint无线打印神器 【免费下载链接】cups-avahi-airprint Docker image for CUPS intended as an AirPrint relay 项目地址: https://gitcode.com/gh_mirrors/cu/cups-avahi-airprint 还在为家里或办公室的老旧打…...