Peter算法小课堂—动态规划

Peter推荐算法书:《算法导论》

图示:

目录

钢条切割

打字怪人


钢条切割

算法导论(第四版)第十四章第一节:钢条切割

题目描述:

给定一根长度为 n 英寸的钢条和一个价格表 p_{i} ,其中 i=1,2,…,n ,求切割方案,使得总销售价格 r_{n}最大。如果 p_{n} 足够大,最优解可能不需要切割钢条。

这道题可以拆分成两个部分:①总价格最大是多少 ②切割方案

先解决①吧。那么,我们定义一下:f[i]表示长度i的钢条最多能买多少钱。j为切割点。状态转移方程怎么写呢?大家先画一张表格,理解一下含义。

样例:

8

1 5 8 9 10 17 17 20

思考过后,是不是特别有灵感?所以说状态转移方程如下图所示

 

原因:枚举i,j。当分割点在j时,卖的价钱就等于p[j]加上后面的部分的最优值,最后再取个最大值即可。

 所以,①正式解决。②呢?我们再定义一个数组fd[i],表示计算f[i]的决策时选择切割多少,然后两重循环,循环内判断最大,fd[i]取值即可,代码不告诉了啊,应该大家都会写。

打字怪人

题目描述:你的儿子小明打字水平有限,当他希望打出某个单词如 smart 时,他会错误地按到键盘上其他字母,例如形成 asnmaaaert 这样的尴尬情况。更加令人崩溃的是,小明还不会用"退回"键或者删除功能来清理错误字母。现在小明从一个词汇表里挑了若干个单词进行打字,词汇表里的所有n个单词都已知。请你识别出小明至少打错了几个字符?换句话说,也就是去掉至少几个字符,可以使剩下的内容由词汇表里的真单词拼写出来?

做这道题之前先看看另外一道简单题吧。如下

你的儿子小明打字水平有限,当他希望打出某个单词如 smart 时,他会错误地按到键盘上其他字母键盘,例如形成 asnmaaaert 这样的尴尬情况。更加令人崩溃的是,小明还不会用"退回"键或者删除功能来清理错误字母,现在请你识别出真正单词每个字母在错误单词中的位置。先输入一行字符串,代表小明的打字内容。第二行字符串代表小明真实希望打的单词。小明会确保正确单词所有字母都会依次出现在他打的内容里。

很好,大家已经学会了套娃式建模了,真不戳。这道题使用双游标会更加游刃有余,下面分析控制元素。游标1:指向正确单词中的目标字母等待匹配;游标2:指向打字内容中的字母。那么,请大家思考一下哪个游标是主要游标,哪个是辅助游标呢?当然,游标1每次移动一格时,游标2可能移动若干格。好了,现在代码应该会写了吧。

string a,b;
cin>>a>>b;
int i=0;
for(int j=0;j<b.size();j++){while(i<a.size()&&a[i]!=b[j])i++;cout<<++i<<" ";
}

回到原题。这一题可能需要dp的知识。首先,大家思考一下状态怎么定义?给出两种选择:①f[i]表示前i个字符最少删除几个才能用真实单词拼接② f[i]表示前i个字符最少删除几个才能用真实单词拼接并确保第i个字母必须保留。思考片刻后,大家不出意外的话应该都会选①。那么,大家真的能快速写出转移方程吗?看来我们要找找规律,那请大家根据1038题的样例输入填写f[i]。

cin>>n>>ls;
cin>>s;
for(int i=1;i<=n;i++) cin>>w[i];
for(int i=1;i<=ls;i++){f[i]=f[i-1]+1;for(int k=1;k<=n;k++){lw=w[k].size();int p=search(i,k);if(p<0) continue;f[i]=min(f[i],f[p]+i-p-lw);}
}
cout<<f[ls]<<endl;

请大家思考一下代码的意思。首先,第5行是一个提前处理。然后第6行实际上就是在第一层枚举的字符串后再挨个添加真实单词,search()是从第i个字母往前查找,遇到w[k]起始点时返回(相当于前铺)

int search(int i,int k){if(i<lw) return -1;if(s[i-1]!=w[k][lw-1]) return -1;int pa=i-1;for(int pb=lw-1;pb>=0;pb--,pa--){while(pa>=0&&s[pa]!=w[k][pb]) pa--;if(pa<0) return -1;}return pa+1;
}

双游标不做解释。

希望这些对大家有用,三连必回

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

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

相关文章

LaTeX写论文,公式后段落取消缩进方法:\noindent

在论文的段落中&#xff0c;需要插入一个公式&#xff0c;按道理公式后应该紧接着是段落的文本内容&#xff0c;但如果直接写的话&#xff0c;编译得到的PDF中呈现出来的却是开头缩进的样子 如果需要取消公式后面的段落缩进&#xff0c;可以使用命令 \noindent 该命令的作用…

十年磨一剑,花为缘享奢app打造行业的又一颠覆性创新

随着国内生活质量的提高&#xff0c;人们对于奢侈品的消费需求也在不断增长。消费者对于高品质、高价值的商品和服务的需求日益增长。2022年我国内地消费者奢侈品市场规模约为4700亿元&#xff0c;预计2023年我国内地消费者奢侈品消费预计将达到5500亿元&#xff0c;呈现出强劲…

华为鸿蒙运行Hello World

前言&#xff1a; 从11月中旬开始通过B站帝心接触鸿蒙&#xff0c;至今一个半月左右不到&#xff0c;从小白到入坑&#xff0c;再到看官网案例&#xff0c;分析案例&#xff0c;了解技术点&#xff0c;还需要理清思路&#xff0c;再写博客&#xff0c;在决定写 &#xff1c;Har…

MessageBox:连接HubSpot和微信的桥梁

在当今充满挑战的商业环境中&#xff0c;成功的企业需要高效整合不同的平台和系统&#xff0c;以提升客户关系管理的水平。在这一复杂的任务中&#xff0c;MessageBox凭借其卓越的功能和灵活性&#xff0c;不仅成为连接HubSpot和微信的桥梁&#xff0c;更是实现精细化客户关系的…

【Spark精讲】SparkSQL的RBO与CBO

Spark SQL核心:Catalyst Spark SQL的核心是Catalyst查询编译器&#xff0c;它将用户程序中的SQL/Dataset/DataFrame经过一系列操作&#xff0c;最终转化为Spark系统中执行的RDD。 Catalyst组成部分 Parser &#xff1a;用Antlr将SQL/Dataset/DataFrame转化成一棵未经解析的树…

PowerBI:如何在以SharePoint文件做为数据源?

问题描述&#xff1a; 有朋友最近询问&#xff0c;在PowerBI中如何以SharePoint中的文件做为数据源&#xff0c;进行报告的设计开发&#xff1f; 今天抽一些时间&#xff0c;为大家做一个样例&#xff0c;供大家参考。 解决方案&#xff1a; 找到将要使用的SharePoint中文件…

计算字符串的长度几种方法 | 递归 | 指针减指针 | 计数器 | C语言 | 详解 | 期末考试必看!!!

一&#xff0c;使用 递归 计算 字符串 的 长度 1&#xff0c;题目描述 2&#xff0c;分析题目 Ⅰ&#xff0c;题目中要求除了函数的形参&#xff0c;函数中不能够使用多余的变量&#xff08;这是比较苛刻的要求&#xff09;。 Ⅱ&#xff0c;根据此&#xff0c;很自然的…

红光护理加按摩放松,试试用清洁仪改善头皮健康

头皮健康和脱发问题现在越来越常见了&#xff0c;所以平时注意改善头皮健康特别重要。这些天我正在用一款名为DOCO红光头皮清洁仪&#xff0c;据说它可以通过多种方式改善头皮健康&#xff0c;我感觉效果还可以。 这款红光头皮清洁仪具有高频振动清洁功能&#xff0c;每分钟可以…

MATLAB习题操作实战

2.1创建一个有7个元素的一维数组&#xff0c;并做如下处理:直接寻访一维数组的第6个元素;寻访一维数组的第1、3、5个元素;寻访一维数组中第4个至最后1个元素;寻访一维数组中大于70的元素。 % 创建一维数组 array [50, 60, 70, 80, 90, 100, 110];% 直接寻访一维数组的第6个元…

55寸oled透明显示屏售价,受哪些因素影响

55寸OLED透明显示屏的售价受到多个因素的影响&#xff0c;包括以下几个方面&#xff1a; 尺寸和分辨率&#xff1a;OLED透明显示屏的尺寸和分辨率是决定价格的重要因素。较大的尺寸和较高的分辨率会增加制造成本和售价。 技术水平和制造工艺&#xff1a;OLED透明显示屏的技术水…

GRU算法

前置知识&#xff1a;RNN&#xff0c;LSTM LSTM需要训练的参数很多&#xff0c;极消耗计算资源。GRU是一种LSTM的改进算法&#xff0c;参数更少&#xff0c;更容易训练。 它将忘记门和输入门合并成为一个单一的更新门&#xff0c;同时合并了数据单元状态和隐藏状态&#xff0…

WPF容器的背景对鼠标事件的影响

背景&#xff1a;在实现鼠标拖动窗口的过程中发现对父容器设置了鼠标拖动窗口的事件MouseLeftButtonDown private void DragWindow(object sender, MouseButtonEventArgs e) {if (e.LeftButton MouseButtonState.Pressed)DragMove(); } 问题&#xff1a;非常困惑的是&#x…