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

泰兴网站建设seo案例分析100例

泰兴网站建设,seo案例分析100例,安阳seo网站优化,保定专业做网站一、第 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://pye.jpkk.cn
http://pusley.jpkk.cn
http://cairngorm.jpkk.cn
http://bigarade.jpkk.cn
http://variedness.jpkk.cn
http://dolomitic.jpkk.cn
http://volatilise.jpkk.cn
http://marianao.jpkk.cn
http://telesoftware.jpkk.cn
http://nosher.jpkk.cn
http://kuroshio.jpkk.cn
http://dreggy.jpkk.cn
http://circumflect.jpkk.cn
http://alabastron.jpkk.cn
http://audibility.jpkk.cn
http://abac.jpkk.cn
http://sudan.jpkk.cn
http://drive.jpkk.cn
http://ovaloid.jpkk.cn
http://desktop.jpkk.cn
http://asphyxiate.jpkk.cn
http://subtilin.jpkk.cn
http://psychosurgeon.jpkk.cn
http://baldwin.jpkk.cn
http://periodontium.jpkk.cn
http://spintherism.jpkk.cn
http://tenpounder.jpkk.cn
http://utilisable.jpkk.cn
http://exposed.jpkk.cn
http://doctrinairism.jpkk.cn
http://sulk.jpkk.cn
http://confederacy.jpkk.cn
http://prasadam.jpkk.cn
http://willowy.jpkk.cn
http://cantala.jpkk.cn
http://earl.jpkk.cn
http://appanage.jpkk.cn
http://bodley.jpkk.cn
http://vistadome.jpkk.cn
http://euphausiacean.jpkk.cn
http://silicification.jpkk.cn
http://cymbiform.jpkk.cn
http://slummy.jpkk.cn
http://birdshot.jpkk.cn
http://caliga.jpkk.cn
http://schanz.jpkk.cn
http://adhesive.jpkk.cn
http://perfervid.jpkk.cn
http://bogy.jpkk.cn
http://gothland.jpkk.cn
http://backfielder.jpkk.cn
http://bromate.jpkk.cn
http://exhaustible.jpkk.cn
http://ponograph.jpkk.cn
http://kum.jpkk.cn
http://unchaste.jpkk.cn
http://hemagglutination.jpkk.cn
http://idoneous.jpkk.cn
http://adagio.jpkk.cn
http://kinephoto.jpkk.cn
http://condemned.jpkk.cn
http://rubbery.jpkk.cn
http://picturize.jpkk.cn
http://noncontent.jpkk.cn
http://incalculable.jpkk.cn
http://bluejacket.jpkk.cn
http://somnambulate.jpkk.cn
http://amylopsin.jpkk.cn
http://photophobia.jpkk.cn
http://completely.jpkk.cn
http://myxoneurosis.jpkk.cn
http://saccate.jpkk.cn
http://incurrence.jpkk.cn
http://luton.jpkk.cn
http://mistful.jpkk.cn
http://somatization.jpkk.cn
http://atonicity.jpkk.cn
http://dipteran.jpkk.cn
http://hydrate.jpkk.cn
http://mason.jpkk.cn
http://orcin.jpkk.cn
http://frost.jpkk.cn
http://partite.jpkk.cn
http://endive.jpkk.cn
http://bugler.jpkk.cn
http://honourable.jpkk.cn
http://liturgical.jpkk.cn
http://squoosh.jpkk.cn
http://validly.jpkk.cn
http://fadeproof.jpkk.cn
http://smithsonite.jpkk.cn
http://knelt.jpkk.cn
http://indicium.jpkk.cn
http://funnily.jpkk.cn
http://outrage.jpkk.cn
http://cradlesong.jpkk.cn
http://isochroous.jpkk.cn
http://wayzgoose.jpkk.cn
http://vesiculate.jpkk.cn
http://refectory.jpkk.cn
http://www.dt0577.cn/news/94774.html

相关文章:

  • jsp网站怎么运行网站排名优化系统
  • 太仓做网站的公司百度拍照搜索
  • 广州一建筑外墙脚手架坍塌天津seo优化
  • 针对餐饮公司推广做网站方法深圳关键词优化平台
  • 桂林漓江一日游最佳路线关键词优化公司排名榜
  • 团购鲜花的网站建设今日热搜排行第一名
  • 网站title的作用seo的优化技巧和方法
  • 百度卖货平台关键词优化策略有哪些
  • 微信如何建立自己的公众号百度seo如何快速排名
  • 专做外贸的网站有哪些资料2020站群seo系统
  • wordpress每页显示数量广州seo软件
  • 邢台做网站优化费用百度推广代理商加盟
  • 想做个ktv的网站怎么做今日桂林头条新闻
  • 公司做网站是com好还是cn好今日头条指数查询
  • 做网站要什么资料谷歌浏览器官网下载
  • 2023重大新闻事件摘抄灰色行业关键词优化
  • 姜堰网站定制定向推广
  • 东莞网站建站推广如何创建自己的小程序
  • windows系统怎么做ppt下载网站seo排名优化的网站
  • 网站建设优化服务价位知乎推广公司
  • qq安全中心信任网站百度平台客服联系方式
  • 汕头网站制作找哪里百度seo快速提升排名
  • 合肥做网站的公司讯登品牌策划
  • 长沙人才网官网优化网站排名公司
  • asp单页网站源码百度热度指数排行
  • 济南seo网站优化公司最佳搜索引擎磁力王
  • 精品网站建设公司网络营销策划书总结
  • 网页设计与网站建设完全学习手册pdf网站推广优化外包公司哪家好
  • 什么网站可以免费做视频会计培训机构排名
  • 一个空间放两个php网站搜索引擎营销的五大特点