动态规划 之 钢条切割

在这里插入图片描述
在这里插入图片描述

自顶向下递归实现(Recursive top-down implementation)
程序CUT-ROD对等式(14.2)进行了实现,伪代码如下:

CUT-ROD(p, n)if n == 0return 0q = -∞for i = 1 to nq = max{q, p[i] + CUT-ROD(p, n - i)}return q

在这里插入图片描述

上面解决中重复对一个子结构问题重复求解了,我们可以把这个过程记录下来

使用动态规划求解最优钢条切割(Using dynamic programming for optimal rod cutting)

在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述


MEMOIZED-CUT-ROD(p, n)let r[0 : n] be a new array    // will remember solution values in rfor i = 0 to nr[i] = -∞return MEMOIZED-CUT-ROD-AUX(p, n, r)MEMOIZED-CUT-ROD-AUX(p, n, r)if r[n] ≥ 0    // already have a solution for length n ?return r[n]if n == 0q = 0else q = -∞for i = 1 to n    // i is the position of the first cutq = max{q, p[i] + MEMOIZED-CUT-ROD-AUX(p, n - i, r)}r[n] = q    // remember the solution value for length nreturn q

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码

#define _CRT_SECURE_NO_WARNINGS
#include<iostream>class Solution {
public:Solution(int x):len(x){}int fun() {for (int i = 0; i <= len; i++) {memory[i] = 0;  // 初始化}for (int i = 1; i <= len; i++){int q = min;for (int k = 1; k <= i; k++){q =std::max( q , price[k] + memory[i - k]);   // 每次切割一次,这是核心record[i] = k;}memory[i] = q;}return memory[len];}private:int price[11] = {0,1,5,8,9,10,17,17,20,24,30};  // 假定数据较小,对应价格int len;int memory[11];   // 记录 int record[11];   // 在哪里切割int min = -1;
};int main()
{Solution a(4);std::cout <<a.fun() << std::endl;
}

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

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

相关文章

java中关键字 volatile 和 synchronized 有什么区别

java中 volatile 和 synchronized 有什么区别&#xff1f;

nodejs微信小程序+python+PHP-青云商场管理系统的设计与实现-安卓-计算机毕业设计

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

微机原理_3

一、单项选择题(本大题共15小题,每小题3分,共45分。在每小题给出的四个备选项中,选出一个正确的答案,请将选定的答案填涂在答题纸的相应位置上。) 在 8086 微机系统中&#xff0c;完成对指令译码操作功能的部件是&#xff08;)。 A. EU B. BIU C. SRAM D. DRAM 使计算机执行某…

企业海外分部,如何实现安全稳定的跨境网络互连?

如今&#xff0c;众多企业广泛采取数字化业务系统&#xff0c;如OA、ERP及CRM等&#xff0c;来提升其业务运营效率。同时&#xff0c;私有云与公有云混合架构也逐渐普及化。 具体来说&#xff0c;很多企业选择将研发系统部署在公司本地的私有云环境&#xff0c;以此确保数据安全…

nvm安装及使用

文章目录 一、[介绍](https://github.com/nvm-sh/nvm)1.1、卸载node1.1.1、从控制面板的程序卸载node1.1.2、删除node的安装目录1.1.3、查找.npmrc文件删除1.1.4、逐一删除下列文件1.1.5、删除node环境变量1.1.6、验证是否卸载成功 二、安装2.1、window系统2.2、mac系统2.2.1、…

LeetCode二叉树小题目

Q1将有序数组转换为二叉搜索树 题目大致意思就是从一个数组建立平衡的二叉搜索树。由于数组以及进行了升序处理&#xff0c;我们只要考虑好怎么做到平衡的。平衡意味着左右子树的高度差不能大于1。由此我们可以想着是否能用类似二分递归来解决。 如果left>right,直接返回nul…

web前端之引入svg图片、html引入点svg文件、等比缩放、解决裁剪问题、命名空间、object标签、阿里巴巴尺量图、embed标签、iframe标签

MENU 前言直接在页面编写svg使用img标签引入通过css引入使用object标签引入其他标签参考资料 前言 web应用开发使用svg图片的方式&#xff0c;有如下几种方式 1、直接在页面编写svg 2、使用img标签引入 3、通过css引入 4、使用object标签引入 直接在页面编写svg 在html页面直接…

Elasticsearch基础教程

​ Elasticsearch是一个实时的分布式搜索分析引擎&#xff0c;底层基于Lucene实现。它提供了一个分布式多用户能力的全文搜索引擎&#xff0c;并且客户端可以使用标准的RESTful进行访问。Elasticsearch是用Java开发的&#xff0c;并作为Apache许可条款下的开放源码发布&#xf…

【CVE-2021-1675】Spoolsv打印机服务任意DLL加载漏洞分析

漏洞详情 简介 打印机服务提供了添加打印机的接口&#xff0c;该接口缺乏安全性校验&#xff0c;导致攻击者可以伪造打印机信息&#xff0c;在添加新的打印机时实现加载恶意DLL。这造成的后果就是以system权限执行任意代码。 影响版本 windows_10 20h2 windows_10 21h1 win…

探索亚马逊云科技云存储服务的性能

文章作者&#xff1a;Libai 引言 随着企业越来越多地依赖云存储解决方案&#xff0c;确保存储性能的最佳状态变得至关重要。在本文中&#xff0c;我们将探讨在亚马逊云科技云存储服务上进行存储性能基准测试的重要性&#xff0c;以及如何帮助企业做出资源分配和优化的明智决策…

RK3588平台 USB框架与USB识别流程

一.USB的基本概念 在最初的标准里&#xff0c;USB接头有4条线&#xff1a;电源&#xff0c;D-,D,地线。我们暂且把这样的叫做标准的USB接头吧。后来OTG出现了&#xff0c;又增加了miniUSB接头。而miniUSB接头则有5条线&#xff0c;多了一条ID线,用来标识身份用的。 热插拔&am…

《C++ Primer》第10章 算法(一)

参考资料&#xff1a; 《C Primer》第5版《C Primer 习题集》第5版 10.1 概述&#xff08;P336&#xff09; 大多数算法定义在头文件 algorithm 中&#xff0c;头文件 numeric 中也定义了一组数值泛型算法。 一般情况下&#xff0c;算法不直接操作容器&#xff0c;而是通过…