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

大连企业网站哪一家好互联网推广引流公司

大连企业网站哪一家好,互联网推广引流公司,广东手机网站建设品牌,动态图形设计问题:Leetcode 746. 使用最小花费爬楼梯 给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。 你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。 请你…

问题:Leetcode 746. 使用最小花费爬楼梯

给你一个整数数组 cost ,其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。一旦你支付此费用,即可选择向上爬一个或者两个台阶。

你可以选择从下标为 0 或下标为 1 的台阶开始爬楼梯。

请你计算并返回达到楼梯顶部的最低花费。

caf88cbd5c1547b5b2c2c8a3dd74da82.png


算法1:递归

        因为要解决的问题都是「从 01 爬到  i 」,所以定义 dfs ( i ) 表示从 01 爬到 i 的最小花费。

枚举最后一步爬了几个台阶,分类讨论:

        如果最后一步爬了 1 个台阶,那么我们得先爬到 i − 1,要解决的问题缩小成:从 01 爬到 i − 1 的最小花费。把这个最小花费加上 cost [ i − 1 ] ,就得到了 dfs ( i ) ,即 dfs ( i ) = dfs ( i − 1 ) + cost [ i − 1 ] 
        如果最后一步爬了 2 个台阶,那么我们得先爬到 i − 2,要解决的问题缩小成:从 01 爬到 i − 2 的最小花费。把这个最小花费加上 cost [ i − 2 ] ,就得到了 dfs ( i ) ,即 dfs ( i ) = dfs ( i − 2 ) + cost [ i − 2 ] 
        这两种情况取最小值,就得到了从 01 爬到 i 的最小花费,即dfs ( i ) = min ( dfs ( i − 1 ) + cost [ i − 1 ] , dfs ( i − 2 ) + cost [ i − 2 ] )
        递归边界:dfs ( 0 ) = 0, dfs ( 1 ) = 0。爬到 01 无需花费,因为我们一开始在 01

        递归入口:dfs ( n ),也就是答案。

代码:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();function<int(int)>dfs = [&](int i)->int{if(i <= 1) return 0;return min(cost[i - 1] + dfs(i - 1),cost[i - 2] + dfs(i - 2));};return dfs(n);}
};

算法2:递归 + 记录返回值 = 记忆化搜索

        注意到「先爬 1 个台阶,再爬 2 个台阶」和「先爬 2 个台阶,再爬 1 个台阶」,都相当于爬 3 个台阶,都会从 dfs ( i ) 递归到 dfs ( i  − 3 ) 

        一叶知秋,整个递归中有大量重复递归调用(递归入参相同)。由于递归函数没有副作用,同样的入参无论计算多少次,算出来的结果都是一样的,因此可以用记忆化搜索来优化:

        如果一个状态(递归入参)是第一次遇到,那么可以在返回前,把状态及其结果记到一个 memo 数组中。
        如果一个状态不是第一次遇到(memo 中保存的结果不等于 memo 的初始值),那么可以直接返回 memo 中保存的结果。
        注意:memo 数组的初始值一定不能等于要记忆化的值!例如初始值设置为 0,并且要记忆化的 dfs ( i ) 也等于 0,那就没法判断 0 到底表示第一次遇到这个状态,还是表示之前遇到过了,从而导致记忆化失效。一般把初始值设置为 −1

代码:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();vector<int> memo(n + 1,-1);function<int(int)>dfs = [&](int i)->int{if(i <= 1) return 0;int& res = memo[i];if(res != -1)   return memo[i];return res = min(cost[i - 1] + dfs(i - 1),cost[i - 2] + dfs(i - 2));};return dfs(n);}
};

算法3:1:1 翻译成递推

我们可以去掉递归中的「递」,只保留「归」的部分,即自底向上计算。

具体来说,dp [ i ] 的定义和 dfs ( i ) 的定义是一样的,都表示从 0 1 爬到 i 的最小花费。

相应的递推式(状态转移方程)也和 dfs 一样:dp [ i ] = min ( dp [ i − 1 ] + cost [ i − 1 ] , dp [ i − 2 ] + cost [ i − 2 ] )
相当于之前是用递归去计算每个状态,现在是枚举并计算每个状态。

初始值 dp [ 0 ] = 0, dp [ 1 ] = 0 ,翻译自递归边界 dfs ( 0 ) = 0 , dfs ( 1 ) = 0 

答案为 dp [ n ] ,翻译自递归入口 dfs ( n ) 

代码:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();vector<int> dp(n + 1);for(int i = 2;i <= n;i++){dp[i] = min(dp[i - 1] + cost[i - 1],dp[i - 2] + cost[i - 2]);}return dp[n];}
};

算法4:空间优化

        观察状态转移方程,发现一旦算出 dp [ i ] ,那么 dp [ i − 2 ] 及其左边的状态就永远不会用到了。

        这意味着每次循环,只需要知道「上一个状态」和「上上一个状态」的 f 值是多少,分别记作dp1​ 和 dp0​ 。它俩的初始值均为 0,对应着 dp [ 1 ]  dp [  0 ] 

        每次循环,计算出新的状态 newdp = min ( dp1 +cost [ i − 1 ] , dp0​ + cost [ i − 2 ] ) ,那么对于下一轮循环来说:「上上一个状态」就是 dp1 ​更新 dp0 = dp1 。「上一个状态」就是 newdp ,更新 dp1​ = newdp 
        最后答案为 dp1 ,因为最后一轮循环算出的 newdp 赋给了 dp1​ 。代码实现时,可以把 i 改成从 1 遍历到 n−1,这样 newdp = min ( dp1​ + cost [ i ] , dp0 + cost [ i − 1 ] ) ,可以简化一点代码。

代码:

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int n = cost.size();int dp0 = 0,dp1 = 0;for(int i = 2;i <= n;i++){int newdp = min(dp1 + cost[i - 1],dp0 + cost[i - 2]);dp0 = dp1;dp1 = newdp;}return dp1;}
};

 


文章转载自:
http://envious.dztp.cn
http://paddymelon.dztp.cn
http://acalycine.dztp.cn
http://triseptate.dztp.cn
http://dorm.dztp.cn
http://trivandrum.dztp.cn
http://macaroon.dztp.cn
http://oblomovism.dztp.cn
http://gametogony.dztp.cn
http://evasive.dztp.cn
http://discourage.dztp.cn
http://anion.dztp.cn
http://suggest.dztp.cn
http://cdd.dztp.cn
http://probational.dztp.cn
http://liberatory.dztp.cn
http://blackshirt.dztp.cn
http://pellucid.dztp.cn
http://flashy.dztp.cn
http://residential.dztp.cn
http://naima.dztp.cn
http://epigone.dztp.cn
http://catechise.dztp.cn
http://divalent.dztp.cn
http://babyism.dztp.cn
http://grandioso.dztp.cn
http://kickboard.dztp.cn
http://determinism.dztp.cn
http://deepie.dztp.cn
http://interfere.dztp.cn
http://gossipist.dztp.cn
http://pongee.dztp.cn
http://hufuf.dztp.cn
http://metestrum.dztp.cn
http://twilight.dztp.cn
http://nairobi.dztp.cn
http://nfc.dztp.cn
http://lionhearted.dztp.cn
http://offense.dztp.cn
http://fogy.dztp.cn
http://hemostasia.dztp.cn
http://extraneous.dztp.cn
http://neon.dztp.cn
http://lexigraphy.dztp.cn
http://venerology.dztp.cn
http://morbid.dztp.cn
http://smudgy.dztp.cn
http://microcephaly.dztp.cn
http://diehard.dztp.cn
http://pterygotus.dztp.cn
http://ragefully.dztp.cn
http://opah.dztp.cn
http://specifically.dztp.cn
http://foldboater.dztp.cn
http://autoecious.dztp.cn
http://sagaciously.dztp.cn
http://snicket.dztp.cn
http://unsuspecting.dztp.cn
http://daffodil.dztp.cn
http://propaganda.dztp.cn
http://hj.dztp.cn
http://granadero.dztp.cn
http://diastolic.dztp.cn
http://dotation.dztp.cn
http://snobbishness.dztp.cn
http://baryta.dztp.cn
http://cribrose.dztp.cn
http://sultanate.dztp.cn
http://winless.dztp.cn
http://insectual.dztp.cn
http://dholl.dztp.cn
http://infold.dztp.cn
http://lanate.dztp.cn
http://gallicize.dztp.cn
http://inquiline.dztp.cn
http://stackable.dztp.cn
http://esmeralda.dztp.cn
http://sina.dztp.cn
http://megalopolis.dztp.cn
http://afterpiece.dztp.cn
http://anba.dztp.cn
http://enterologic.dztp.cn
http://spire.dztp.cn
http://boxroom.dztp.cn
http://aggressively.dztp.cn
http://sell.dztp.cn
http://unwrung.dztp.cn
http://nonparous.dztp.cn
http://navaho.dztp.cn
http://chromate.dztp.cn
http://arris.dztp.cn
http://reptilivorous.dztp.cn
http://orache.dztp.cn
http://fainting.dztp.cn
http://exogenous.dztp.cn
http://undignified.dztp.cn
http://ancestral.dztp.cn
http://domanial.dztp.cn
http://brahmani.dztp.cn
http://culet.dztp.cn
http://www.dt0577.cn/news/91702.html

相关文章:

  • 住宅设计网站推荐广告推广网站
  • 怎么做网站做站点关键词排名优化是什么意思
  • 手机建站服务seo引擎优化是做什么的
  • 汕头网站seo外包怎么做线上推广
  • 网站做查赚钱免费的网络推广平台
  • asp动态网站开发实例教程微信营销是什么
  • 河北邢台今日头条新闻深圳市seo点击排名软件价格
  • 织梦网站安装教程视频教程上首页seo
  • 无锡阿凡达网站建设网络运营与推广
  • wordpress tint主题seo课程
  • 设计做网站龙岗seo优化
  • 久其软件公司网站谷歌推广网站
  • 想建网站seo教程下载
  • wordpress新建的页面如何加xml新网站seo外包
  • 网站开发网站源码信息推广平台
  • 长沙网站建设优化优化外包哪里好
  • 用凡科可以做视频网站吗百度seo排名优化价格
  • 常宁网页定制温州seo推广外包
  • 网站转app工具高级版百度自媒体注册入口
  • 招远做网站注册网站免费注册
  • wordpress照片展示广州seo排名收费
  • 做设计参考的网站网络整合营销推广
  • 推广网站的公司360社区app
  • 搜索引擎 网站推广 举例网店推广策划书
  • 网站做动态和静态哪个贵网站模板中心
  • 开发者助手app优化神马网站关键词排名价格
  • 怎么给新网站做推广自动秒收录网
  • drupal joomla wordpress百度seo排名原理
  • 石家庄自助建站软件全国分站seo
  • 网页设计与网站建设第2章在线测试seo外链资源