【LeetCode】每日一题 2024_11_11 切棍子的最小成本(区间 DP,记忆化搜索)

server/2024/11/14 23:41:42/

前言

每天和你一起刷 LeetCode 每日一题~

LeetCode 启动!

题目:leetcode.cn/problems/minimum-cost-to-cut-a-stick/description/?envType=daily-question&envId=2024-11-11" rel="nofollow">切棍子的最小成本

双十一光棍节力扣给我们准备了 . . . 一根棍子

代码与解题思路

先读题:

题目给了 n 代表棍子的长度,给了 cuts 数组代表我们需要在这几个地方砍这根棍子,每次砍的时候会累加当前棍子长度的成本,让我们找出成本最小的砍法

有没有数学的解法我不太清楚,但最简单的思路就是,枚举切割这根棍子的所有情况,找出成本的最小值,那该如何枚举呢?

dfs(i, j),i j 作为当前木棍的左右边界,我们枚举 k 作为切割的位置,切割后木棍的成本就是:dfs(i, k)+dfs(k, j),而当前木棍的成本是:cuts[j]-cuts[i],具体代码如下:

func minCost(n int, cuts []int) int {cuts = append(cuts, 0, n) // 增加头和尾slices.Sort(cuts) // 排序方便操作n = len(cuts) // 现在的 n 是 cuts 数组的长度memo := make([][]int, n)for i := range memo {memo[i] = make([]int, n)}var dfs func(int, int) intdfs = func(i, j int) int { // i j 作为 cuts 数组的下标if i+1 == j { // 中间没有可以切割的点了,不用切割了return 0 }p := &memo[i][j] // 记忆化if *p != 0 {return *p}res := math.MaxIntfor k := i+1; k < j; k++ { // 枚举切割的位置// dfs(i, k)+dfs(k, j) 切割后的两段木棍的成本和res = min(res, dfs(i, k)+dfs(k, j))}*p = res + cuts[j]-cuts[i] // 切割后两段木棍的成本+当前的成本return *p}return dfs(0, n-1)
}

想这样区间相关的动态规划问题应该是区间 DP,这也是我第一次做区间 DP 相关的题目呢~

最近力扣 DP 也是越来越多了

每天进步一点点,我们明天不见不散~

可以和我刷一辈子的每日一题吗?
一题一题,积累起来就是一辈子。


http://www.ppmy.cn/server/141966.html

相关文章

Java入门16——接口

我们今天来学习接口&#xff0c;和继承有点像&#xff0c;话不多说&#xff0c;开始正题~ 一、接口 1.为什么要用接口 接口其实和继承很像&#xff0c;但是继承是 is-a 的关系&#xff0c;接口是 has-a 的关系&#xff0c;而且继承只能是一对一的关系&#xff0c;但是接口可以…

Docker的基础使用

一、Docker使用步骤&#xff08;kali为例&#xff09; 1.安装Docker&#xff1a; &#xff08;1&#xff09;更新系统包索引&#xff1a; sudo apt-get update &#xff08;2&#xff09;安装Docker&#xff1a; sudo apt-get install docker.io 2.配置docker源&#xff…

unity基础,点乘叉乘。

简单记录下点乘叉乘&#xff0c;要不每次用完就忘&#xff0c;忘了又查。 using System.Collections; using System.Collections.Generic; using UnityEngine;public class TestCrossDot : MonoBehaviour {/// <summary>/// 原点/// </summary>public Transform t…

恒创科技:什么是 RAID 3 ? RAID 3、4 和5之间有什么区别?

RAID 是一种存储数据以提高性能并减少数据丢失的特定技术。您可以根据自己的需求选择多种 RAID 类型。RAID 3 是列表中比较有效的类型之一。本文将重点介绍这种特定的 RAID 技术&#xff0c;并比较 RAID 3、4 和 5。 RAID 3 的定义 RAID 3 是一种特定的磁盘配置&#xff0c;用于…

PyTorch nn.Embedding介绍

nn.Embedding 是 PyTorch 中用于将离散的整数索引(代表类别或符号)转换为连续向量表示的层。这个嵌入层特别适合用于自然语言处理、序列数据、推荐系统、以及生物信息学中的离散符号编码(如氨基酸序列等)等任务。 一、nn.Embedding 的定义和参数 nn.Embedding(num_embedd…

【MIT-OS6.S081笔记1】Chapter1阅读摘要:Operating system interfaces

记录阅读《xv6: a simple, Unix-like teaching operating system》的一些摘要&#xff0c;这是第一章的内容&#xff1a;Operating system interfaces。 fork函数作用&#xff1a;fork创建一个新进程&#xff0c;称为子进程&#xff0c;其内存内容与调用进程&#xff08;称为父…

React Hooks在现代前端开发中的应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 React Hooks在现代前端开发中的应用 React Hooks在现代前端开发中的应用 React Hooks在现代前端开发中的应用 引言 React Hooks …

开源模型应用落地-qwen模型小试-Qwen2.5-7B-Instruct-tool usage入门-Qwen-Agent初体验(一)

一、前言 Qwen-Agent 是一个利用开源语言模型Qwen的工具使用、规划和记忆功能的框架。其模块化设计允许开发人员创建具有特定功能的定制代理,为各种应用程序提供了坚实的基础。同时,开发者可以利用 Qwen-Agent 的原子组件构建智能代理,以理解和响应用户查询。 本篇将介绍如何…