钢条切割问题是一个经典的动态规划问题,旨在通过切割钢条获得最大收益。以下是详细解释和解决方案:

问题描述

  • 给定长度为 n 的钢条和价格表 p,其中 p[i] 表示长度为 i 的钢条的价格(i = 1, 2, ..., n)。
  • 目标:找到切割方案,使销售收益最大化。

动态规划解法

核心思想
  • 最优子结构:长度为 n 的钢条的最优解包含子问题的最优解(例如,切割成两段后,每段的最优解)。
  • 递归关系
    • r[i] 为长度为 i 的钢条的最大收益。

    • 初始值:r[0] = 0(长度为 0 的钢条收益为 0)。

    • 递推公式:

      r[i] = max_{1≤j≤min(i, m)} { p[j] + r[i - j] }

      其中 m 是价格表的最大长度(即 m = len(p)),j 是第一段切割的长度。

算法步骤
  1. 初始化

    • 创建数组 r[0..n] 存储最大收益,r[0] = 0
    • 创建数组 s[0..n] 存储切割方案,s[i] 记录长度为 i 时第一段切割的长度。
  2. 自底向上计算

    • 遍历长度 i 从 1 到 n
      • 初始化 q = -∞(临时变量,存储当前最大收益)。
      • 遍历切割长度 j 从 1 到 i
        • j 超出价格表范围(j > m),跳过。
        • 否则,计算收益 temp = p[j] + r[i - j]
        • temp > q,更新 q = temp 并记录 s[i] = j
      • 设置 r[i] = q
  3. 回溯切割方案

    • i = n 开始:
      • 输出 s[i](第一段切割长度)。
      • 更新 i = i - s[i],重复直到 i = 0

时间复杂度和空间复杂度

  • 时间复杂度O(n^2)(双重循环)。
  • 空间复杂度O(n)(存储 rs 数组)。

示例演示

假设 n = 4,价格表 p = [0, 1, 5, 8, 9](索引从 1 开始):

  • 计算过程
    • i=1j=1r[1] = p[1] + r[0] = 1s[1]=1
    • i=2j=11 + r[1]=2j=25 + r[0]=5r[2]=5, s[2]=2
    • i=3j=38 + r[0]=8r[3]=8, s[3]=3
    • i=4j=25 + r[2]=10r[4]=10, s[4]=2
  • 切割方案4 → 2 + 2(收益 5 + 5 = 10)。

**代码实现(Python)

def rod_cutting(n, p):m = len(p) - 1  # 价格表最大长度(索引从1开始)r = [-10**18] * (n + 1)  # 最大收益数组s = [0] * (n + 1)         # 切割方案数组r[0] = 0     # 初始化# 动态规划填表for i in range(1, n + 1):q = -10**18for j in range(1, i + 1):if j > m:  # j超出价格表范围continuetemp = p[j] + r[i - j]if temp > q:q = temps[i] = jr[i] = q# 回溯切割方案solution = []i = nwhile i > 0:solution.append(s[i])i -= s[i]return r[n], solution

示例

n = 4
p = [0, 1, 5, 8, 9] # p[0]无效,p[1]=1, p[2]=5, …
max_profit, cuts = rod_cutting(n, p)
print(“最大收益:”, max_profit) # 输出: 10
print(“切割方案:”, cuts) # 输出: [2, 2]

关键点

  • 价格表处理:索引从 1 开始,p[j] 直接对应长度 j 的价格。
  • 边界处理:当 j > m 时跳过(长度超出价格表范围)。
  • 方案回溯:利用 s 数组逐步还原切割段。

此方法高效地解决了钢条切割问题,适用于任意长度的钢条和价格表。

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

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

相关文章

DeepSeek:中国AI开源先锋的技术突破与行业革新

在人工智能技术迅猛发展的浪潮中,DeepSeek(深度求索)作为中国AI领域的新锐力量,凭借其创新的技术路线和开源策略,正在全球AI舞台上崭露头角。这家由知名量化投资机构幻方量化支持的AI公司,自2023年7月成立以…

cmake:动态链接库(dll)的调用

如题,动态链接库的调用和静态链接库有所不同,现将步骤整理如下。 动态链接库文件 正常情况下,编译的动态链接库有五个生成文件和对应的头文件,在调用中,使用dll文件,lib文件 和头文件。编译生成动态库的步骤和配置见C++:动态链接库的编写,__declspec 用法详解-CSDN博…

SAP调用api

之前是把SAP程序封装成api,然后又接到了需求是sap调用其他api,直接上代码吧 FUNCTION ZRFC_PP_016. *"---------------------------------------------------------------------- *"*"Local interface: *" IMPORTING *" …

Idea/Pycharm用法总结

在目录里展开当前文件

Python打卡训练营Day56

DAY 56 时序数据的检验 知识点回顾: 假设检验基础知识 原假设与备择假设P值、统计量、显著水平、置信区间 白噪声 白噪声的定义自相关性检验:ACF检验和Ljung-Box 检验偏自相关性检验:PACF检验 平稳性 平稳性的定义单位根检验 季节性检验 ACF检…

[GESP202312 五级] 烹饪问题

题目描述 有 N N N 种食材,编号从 0 0 0 至 N − 1 N-1 N−1,其中第 i i i 种食材的美味度为 a i a_i ai​。 不同食材之间的组合可能产生奇妙的化学反应。具体来说,如果两种食材的美味度分别为 x x x 和 y y y ,那么它们…

JSON Mock 工具:从接口模拟到前端联调(二)

JSON Mock 工具:模拟JSON API 接口(一)-CSDN博客 上一篇学习到,JSON Mock 工具,是用于模拟返回 JSON 数据的 API 接口,解决后端接口未就绪时前端无法开发测试的问题,实现 “无后端依赖” 的前端…

质量小议55 - 搜索引擎与AI

先有搜索引擎(谷歌、百度),后有AI(chatGPT,deepSeek,文心一主,CSDN助手) 慢慢的百度用的少了,更多的是直接向AI工具提问 虽然搜索引擎也有了AI版的结果,而且是置顶的,但更多的时间在用A…

Life:Internship in OnSea Day 0

Prolog This will be a new serial Blog to record my internship life in OnSea(I like this straightly translation of hell divers). As usual,这些 Blogs 主要还是给 自分自身 看的,以便日后考古自己的 career。 既然已经这个系列归类到了 Life 类…

ChangeNotifierProvider 本质上也是 Widget

场景 void main() {runApp(MyApp()); }class MyApp extends StatelessWidget {const MyApp({super.key});overrideWidget build(BuildContext context) {return ChangeNotifierProvider(create: (context) > MyAppState(),child: MaterialApp(title: Namer App,theme: Them…

【软考高级系统架构论文】论负载均衡技术在Web系统中的应用

论文真题 负载均衡技术是提升Web系统性能的重要方法。利用负载均衡技术,可将负载(工作任务)进行平衡、分摊到多个操作单元上执行,从而协同完成工作任务,达到提升Web系统性能的目的。 请围绕“负载均衡技术在Web系统中的应用”论题&#xff…

pyqt5工具-串口调试工具

目录 功能界面代码功能 串口设置:支持选择串口、波特率、数据位、停止位和校验位 串口操作:扫描串口、打开 / 关闭串口连接 数据收发: 支持文本和 Hex 模式显示与发送 可设置自动添加换行符 接收区自动滚动 支持中文显示 辅助功能:清空接收区、状态栏显示连接状态 多串口管…

Mybatis-Plus支持多种数据库

使用Mybatis-Plus进行数据库的访问,但是由于不同的数据库有不同的方言,所以需要进行适配。 有2种实现方式: databaseId方式Mapper Location方式 指定databaseId方式 通过databaseId指定所使用的数据库,选择同步的SQL。 Mappe…

【系统分析师】2018年真题:综合知识-答案及详解

【第1题】 面向对象分析中,对象是类的实例。对象的构成成分包含了(1),属性和方法(或操作)。 (1)A.标识 B.消息 C.规则 D.结构 【解析】本题考查的是面向对象的基本概念 对象的三要素为:属性…

从Git历史中删除大文件的完整解决方案

从Git历史中删除大文件的完整解决方案 当你意外提交了一个大文件导致无法推送到远程仓库时,可以按照以下步骤彻底从Git历史中删除这个大文件。 情况分析 首先确认你的问题属于以下哪种情况: 大文件在最近一次提交中:相对容易处理大文件在…

[xiaozhi-esp32] 应用层(9种state) | 音频编解码层 | 双循环架构

第三章:应用层 在第一章:开发板抽象层中,我们实现了硬件交互标准化;在第二章:通信协议层中,我们构建了云端通信桥梁。 现在需要将这些能力有机整合——这便是应用层的使命 应用层的本质 应用层是设备的…

Java 锁升级的过程详解

Java 锁升级的过程详解 Java 虚拟机(JVM)为了提高多线程并发的效率,对内置锁(synchronized 关键字)的实现进行了一系列优化。这些优化体现在锁的升级过程中,即当竞争程度从低到高变化时,锁的状态会从偏向锁逐渐升级为轻量级锁,最终升级为重量级锁。这个过程是不可逆的…

使用vitis tcl脚本构建vitis app工程

一:最近重新学习了zynq系列开发,想着使用tcl创建工程,因此分享一下脚本例子 #!/bin/bashsource /tools/Xilinx/Vitis/2022.2/settings64.sh cd ../../ . ./script/project.sh cd app/script #tcl脚本只能在虚拟机桌面执行 xsct build_vitis…

电脑商城--购物车

加入购物车 1 购物车-创建数据表 1.使用use命令先选中store数据库。 USE store; 2.在store数据库中创建t_cart用户数据表。 CREATE TABLE t_cart (cid INT AUTO_INCREMENT COMMENT 购物车数据id,uid INT NOT NULL COMMENT 用户id,pid INT NOT NULL COMMENT 商品id,price BIG…

2024-2025学年度下期《网页设计》期末模拟测试

一、 单选题 1. HTML文档的根标签是( ) A. <html> B. <head> C. <body> D. <!DOCTYPE> 2. 用于定义段落内容的标签是&#xff1a;( ) A. <div> B. <p> C. <span> D. <br> 3. 网以下哪个属性用于定义CSS内联样式…