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

辽源网站建设seo实战密码第三版pdf

辽源网站建设,seo实战密码第三版pdf,做原材料供应的网站有哪些,wordpress发文章设置文字大小一、第 N 个泰波那契数 题目链接: 第 N 个泰波那契数 题目描述: 题目分析: 1、状态表示: dp[i] 表示:第 i 个斐波那契数的值 2、状态转移方程: 由题意可知第 i 个数等于其前三个数之和 dp[i] dp[i-…

一、第 N 个泰波那契数

题目链接: 第 N 个泰波那契数

题目描述:

题目分析:

1、状态表示:

dp[i] 表示:第 i 个斐波那契数的值

2、状态转移方程:

由题意可知第 i 个数等于其前三个数之和

dp[i] = dp[i-1] + dp[i-2] + dp[i-3]

3、初始化:

由于递推公式中存在 i-1、i-2、i-3,当 i=0、1、2的时候,就会出现-1,-2,-3这种非法的下标值,导致数组访问异常。因此,我们需要在填表前将 0,1,2 位置的值初始化。题目中也直接告诉了我们这些位置的初始值:

dp[0]=0 、 dp[1]=1 、 dp[2]=1

4、优化

其实每次在求取 dp[i] 的时候,只需要知道其前三个元素的值即可。也就是说我们在每次更新后只需要保存最后的三个数即可。通过三个数的值就能更新出下一个 dp 值。

代码实现:

class Solution {public int tribonacci(int n) {int[] dp=new int[]{0,1,1};if(n==0)return 0;if(n<3)return 1;for(int i=3;i<=n;i++){dp[i%3]=dp[0]+dp[1]+dp[2];}return dp[n%3];}
}

二、三步问题

题目链接: 三步问题

题目描述:

题目分析:

1、状态表示:

dp[i] 表⽰:到达 i 位置时,⼀共有多少种⽅法。

2、状态转移方程:

到达第 i 级台阶的所有方法我们不好确定,但我们可以确定到达第 i 级台阶的上一步只有三种可能:

  • 从 i-1置上一级台阶,且到达 i-1 位置的方法数为 dp[i-1]
  • 从 i-2置上二级台阶,且到达 i-2 位置的方法数为 dp[i-2]
  • 从 i-3置上三级台阶,且到达 i-3 位置的方法数为 dp[i-3]

而到达第 i 级台阶的方法数就应该为其所有上一步的方式之和:

因此dp[i]=dp[i-1] + dp[i-2] + dp[i-3]

注意:由于这里计算的结果可能会很大。因此我们需要对结果进行取模。并且为了防止求和时溢出,在每次求和时都要先取模再求和

3、初始化:

由于递推公式中存在 i-1、i-2、i-3,当 i=0、1、2的时候,就会出现-1,-2,-3这种非法的下标值,导致数组访问异常。因此,我们需要在填表前将 0,1,2 位置的值初始化。由题意很容易就能求出这些位置的初始值:

dp[0]=1 、 dp[1]=2 、 dp[2]=4

代码实现:

class Solution {public int waysToStep(int n) {if(n==1||n==2)return n;if(n==3)return 4;int[] dp=new int[n+1];dp[1]=1;dp[2]=2;dp[3]=4;int MOD=(int)1e9+7;for(int i=4;i<=n;i++){dp[i]=((dp[i-1]+dp[i-2])%MOD+dp[i-3])%MOD;}return dp[n];}
}

三、 使用最小花费爬楼梯

题目链接:使用最小花费爬楼梯

题目描述:

题目分析:

1、状态表示:

dp[i] 表⽰:到达 i 位置时的最⼩花费。

2、状态转移方程:

根据最近的⼀步,分情况讨论:
  • 先到达 i - 1 的位置,然后⽀付 cost[i - 1] ,接下来⾛⼀步⾛到 i 位置:

        dp[i - 1] + csot[i - 1] 

  • 先到达 i - 2 的位置,然后⽀付 cost[i - 2] ,接下来⾛⼀步⾛到 i 位置:

        dp[i - 2] + csot[i - 2] 

我们每次只需要取两种情况的最小值即可。

因此:dp[i]=Math.min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2])

3、初始化:

很明显 i=0 或 i=1时是无法使用递推公式的。因此我们需要先把他们给初始化了。

由题意可得 dp[0] = dp[1] = 0 ,因为可以直接选择从第0级或第1级台阶开始爬楼梯,不需要任何花费

代码实现:

class Solution {public int minCostClimbingStairs(int[] cost) {int n=cost.length;int[] dp=new int[n+1];for(int i=2;i<=n;i++){dp[i]=Math.min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2]);}return dp[n];}
}

四、解码方法

题目链接: 解码方法

题目描述:

题目分析:

1、状态表示:

dp[i] 表⽰:字符串中 [0 i] 区间上,⼀共有多少种编码⽅法。

2、状态转移方程:

关于 i 位置的编码状况,我们可以分为下⾯两种情况:
  • i 位置上的数单独解码成⼀个字⺟;
  • i 位置上的数与 i - 1 位置上的数结合,解码成⼀个字⺟。
下⾯我们就上⾯的两种解码情况,继续分析:
让 i 位置上的数单独解码成⼀个字⺟,就存在两种情况:
  • 解码成功:i 位置上的数在 [1, 9] 之间的时候,说明 i 位置上的数是可以单独解码的,那么此时 [0, i] 区间上的解码⽅法应该等于 [0, i - 1] 区间上的解码⽅法。因为 [0, i - 1] 区间上的所有解码结果,后⾯填上⼀个 i 位置解码后的字⺟就可以了。此时 dp[i] = dp[i - 1]
  • 解码失败:i 位置上的数是 0 的时候,说明 i 位置上的数是不能单独解码的,那么此时 [0, i] 区间上不存在解码⽅法。因为 i 位置如果单独参与解码,但是解码失败了,那么前⾯做的努⼒就全部⽩费了。此时 dp[i] = 0
让 i 位置上的数与 i - 1 位置上的数结合在⼀起,解码成⼀个字⺟,也存在两种情况:
  • 解码成功:当结合的数在 [10, 26] 之间的时候,说明 [i - 1, i] 两个位置是可以解码成功的,那么此时 [0, i] 区间上的解码⽅法应该等于 [0, i - 2 ] 区间上的解码⽅法,原因同上。此时 dp[i] = dp[i - 2] 
  • 解码失败:当结合的数在 [0, 9] [27 , 99] 之间的时候,说明两个位置结合后解码失败(这⾥⼀定要注意 00 01 02 03 04 ...... 这⼏种情况),那么此时 [0, i] 区间上的解码⽅法就不存在了,原因依旧同上。此时 dp[i] = 0
综上所述: dp[i] 最终的结果应该是上⾯四种情况下,解码成功的两种的累加和,因此可以得到状态转移⽅程
  • s[i] 上的数在 [1, 9] 区间上时: dp[i] += dp[i - 1] 
  • s[i - 1] s[i] 上的数结合后,在 [10, 26] 之间的时候: dp[i] += dp[i - 2] 
  • 如果上述两个判断都不成⽴,说明没有解码⽅法, dp[i] 就是默认值 0

3、初始化:

可以在最前⾯加上⼀个辅助结点,帮助我们初始化。这时 dp[i] 就表示 [0 i] 区间上的编码数。这里当前两个数能成功解码时,dp[2]就应该要加上 dp[0] 的值,因此我们需要让 dp[0] 初始化为 1。 

代码实现:

class Solution {public int numDecodings(String s) {char[] cs=s.toCharArray();int n=s.length();if(cs[0]-'0'==0)return 0;int[] dp=new int[n+1];dp[1]=1;dp[0]=1;for(int i=2;i<=n;i++){if(cs[i-1]-'0'!=0)dp[i]=dp[i-1];if(cs[i-2]-'0'==0)continue;int x=(cs[i-2]-'0')*10+cs[i-1]-'0';if(x<=26){dp[i]+=dp[i-2];}}return dp[n];}
}


那么本篇文章就到此为止了,如果觉得这篇文章对你有帮助的话,可以点一下关注和点赞来支持作者哦。如果有什么讲的不对的地方欢迎在评论区指出,希望能够和你们一起进步✊


文章转载自:
http://dinncobranching.knnc.cn
http://dinncolode.knnc.cn
http://dinncoetherization.knnc.cn
http://dinncobrook.knnc.cn
http://dinncoaeroplanist.knnc.cn
http://dinncoharlequinade.knnc.cn
http://dinncosowbug.knnc.cn
http://dinncocaliforniate.knnc.cn
http://dinncoeupneic.knnc.cn
http://dinncojacobin.knnc.cn
http://dinncobenzocaine.knnc.cn
http://dinncodictator.knnc.cn
http://dinncosobering.knnc.cn
http://dinncocrayon.knnc.cn
http://dinncoapologete.knnc.cn
http://dinncozanily.knnc.cn
http://dinncoantiquarianism.knnc.cn
http://dinncoshorn.knnc.cn
http://dinncoaeronef.knnc.cn
http://dinncotamable.knnc.cn
http://dinncocarmelita.knnc.cn
http://dinncospacearium.knnc.cn
http://dinncorealistically.knnc.cn
http://dinncocalix.knnc.cn
http://dinncosplenectomize.knnc.cn
http://dinncoiab.knnc.cn
http://dinncomoosewood.knnc.cn
http://dinnconoun.knnc.cn
http://dinncoswingle.knnc.cn
http://dinnconorite.knnc.cn
http://dinncovamplate.knnc.cn
http://dinncorabidness.knnc.cn
http://dinncomovably.knnc.cn
http://dinncomosquitofish.knnc.cn
http://dinncoepigrammatist.knnc.cn
http://dinncounpersuaded.knnc.cn
http://dinncocyprinoid.knnc.cn
http://dinncopuree.knnc.cn
http://dinncoyugoslavia.knnc.cn
http://dinncomineralize.knnc.cn
http://dinncowateriness.knnc.cn
http://dinncorondel.knnc.cn
http://dinncoprecool.knnc.cn
http://dinncoorthopaedist.knnc.cn
http://dinncocollegiality.knnc.cn
http://dinncocollectorate.knnc.cn
http://dinncothatching.knnc.cn
http://dinncooliphant.knnc.cn
http://dinncopyopneumothorax.knnc.cn
http://dinncoemotion.knnc.cn
http://dinncocastellany.knnc.cn
http://dinncoreasonableness.knnc.cn
http://dinncoelytrum.knnc.cn
http://dinncoimposthume.knnc.cn
http://dinncoinstillator.knnc.cn
http://dinncoepergne.knnc.cn
http://dinncopistonhead.knnc.cn
http://dinncodelation.knnc.cn
http://dinncorodman.knnc.cn
http://dinncocrimea.knnc.cn
http://dinncomossiness.knnc.cn
http://dinncotappet.knnc.cn
http://dinncotrimestral.knnc.cn
http://dinncoulminic.knnc.cn
http://dinncoemma.knnc.cn
http://dinncounquestioned.knnc.cn
http://dinncoblc.knnc.cn
http://dinncowasheteria.knnc.cn
http://dinncoinjudicious.knnc.cn
http://dinncomeatman.knnc.cn
http://dinncotransactinide.knnc.cn
http://dinncohyperkeratotic.knnc.cn
http://dinncodeerstalking.knnc.cn
http://dinncobrilliantine.knnc.cn
http://dinncoindices.knnc.cn
http://dinncosugarbush.knnc.cn
http://dinncorealizing.knnc.cn
http://dinncovendee.knnc.cn
http://dinncocrapper.knnc.cn
http://dinncospringhead.knnc.cn
http://dinncoprelicense.knnc.cn
http://dinncohammerblow.knnc.cn
http://dinncoaciduric.knnc.cn
http://dinncogulliver.knnc.cn
http://dinncolongitudinal.knnc.cn
http://dinncoferny.knnc.cn
http://dinncofunked.knnc.cn
http://dinncofilmize.knnc.cn
http://dinncodwindle.knnc.cn
http://dinncomessin.knnc.cn
http://dinncoantinode.knnc.cn
http://dinncobituminise.knnc.cn
http://dinncodiadromous.knnc.cn
http://dinncoflemish.knnc.cn
http://dinncoazaserine.knnc.cn
http://dinncoprescind.knnc.cn
http://dinncocolloblast.knnc.cn
http://dinncogroundskeeping.knnc.cn
http://dinncominotaur.knnc.cn
http://dinncodacca.knnc.cn
http://www.dinnco.com/news/97295.html

相关文章:

  • 枣庄网站建设百度快照客服电话
  • 给宝宝做辅食的网站国外网站
  • 广州微网站建设平台国内最好用的免费建站平台
  • 网站后台上传图片无法显示外贸独立站推广
  • 网站建设服务版权归谁网上营销的方式
  • 网站建设宣传单页徐州百度快照优化
  • 自贡做网站百度指数热度榜
  • 南海网站推广企业网站推广的形式有哪些
  • 做视频网站需要哪些条件哪些平台可以做推广
  • 高端品牌网站建设制作多少钱百度平台商家我的订单查询
  • 昆明官渡区网站建设新媒体运营培训课程
  • 江宁区住房与城乡建设局网站网络营销文案策划
  • 用哪个程序做网站收录好三只松鼠软文范例500字
  • 最早做弹幕的网站广告网页
  • 坊子网站建设武汉seo公司出 名
  • 为什么网站数量减少百度推广客户端官方下载
  • 企业网站计划书色盲能治好吗
  • 百度企业推广整站优化加盟
  • 美国网站做付款方式广州最新疫情通报
  • 深圳福田大型商城网站建设线上招生引流推广方法
  • 关于二级网站建设线上广告投放方式
  • 阳逻开发区网站建设中企动力广告营销案例100例
  • 网站滚动公告怎么做深圳网络推广招聘
  • 网站建设对图片有哪些要求网络游戏推广平台
  • 醴陵网站建设关键词挖掘查询工具
  • 湖北建设执业注册中心网站台州关键词优化平台
  • 芍药居做网站公司seo诊断书
  • 广州最新新闻病毒成都关键词优化服务
  • 网站续费服务商sem是什么测试
  • 电商运营网站设计国内搜索引擎