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

大网站怎样选域名阳泉购物网站开发设计

大网站怎样选域名,阳泉购物网站开发设计,房地产新闻头条,公司建设网站有什么好处一、LeetCode509. 斐波那契数 题目链接:509. 斐波那契数 题目描述: 斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是&#xff1a…

一、LeetCode509. 斐波那契数

题目链接:509. 斐波那契数
题目描述:

斐波那契数 (通常用 F(n) 表示)形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是:

F(0) = 0,F(1) = 1
F(n) = F(n - 1) + F(n - 2),其中 n > 1

给定 n ,请计算 F(n) 。

示例 1:

输入:n = 2
输出:1
解释:F(2) = F(1) + F(0) = 1 + 0 = 1

示例 2:

输入:n = 3
输出:2
解释:F(3) = F(2) + F(1) = 1 + 1 = 2

示例 3:

输入:n = 4
输出:3
解释:F(4) = F(3) + F(2) = 2 + 1 = 3

提示:

  • 0 <= n <= 30
算法分析:

根据动规五部曲来就可以了。

这道题题目已经给了我们地推的公式F[n]=F[n-1]+F[n-2],以及其初始值F[0]=1,F[1]=1,所以我们只需要明白F[n]及其下标的含义就可以了。

显然F[n]表示数列中第n项数的值。

然后我们来遍历整个数组,按照递推公式依次确定每个项的值。

最后返回第n项F[n]即可。

如果算出来的结果有问题,可以把数组打印出来,检查递推是否有问题。

代码如下:

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

时间复杂度o(n)空间复杂度o(n).

二、LeetCode70. 爬楼梯

题目链接:70. 爬楼梯
题目描述:

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例 1:

输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 2 阶

示例 2:

输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
1. 1 阶 + 1 阶 + 1 阶
2. 1 阶 + 2 阶
3. 2 阶 + 1 阶

提示:

  • 1 <= n <= 45
算法分析:
确定dp数组及下标含义:

用dp[i]表示爬到第i阶楼梯可以有多少种方法。

递推公式:

第i阶楼梯可以由i-1阶楼梯跳一步上来,也可以由i-2阶楼梯跳两步上来。

所以到达第i阶楼梯可以有dp[i-1]+dp[i-2]种方法,即dp[i] = dp[i-1]+dp[i-2]。

初始化:

爬上第一阶楼梯有一种方法,即从第0阶向上爬一步,所以dp[1]=1;

爬上第二阶楼梯有两种方法,从第0阶向上一次性爬两步到第二阶,或者向上爬两次,一次爬一步到第二阶,所以dp[2]=2。

遍历顺序:

从前往后依次遍历并确定到达每阶楼梯所需要的方法。

如果结果有问题,打印dp数组,查看是否跟自己推导的一致。

代码如下:

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

时间复杂度o(n),空间复杂度o(n).

三、LeetCode746. 使用最小花费爬楼梯

题目链接:746. 使用最小花费爬楼梯
题目描述:

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

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

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

示例 1:

输入:cost = [10,15,20]
输出:15
解释:你将从下标为 1 的台阶开始。
- 支付 15 ,向上爬两个台阶,到达楼梯顶部。
总花费为 15 。

示例 2:

输入:cost = [1,100,1,1,1,100,1,1,100,1]
输出:6
解释:你将从下标为 0 的台阶开始。
- 支付 1 ,向上爬两个台阶,到达下标为 2 的台阶。
- 支付 1 ,向上爬两个台阶,到达下标为 4 的台阶。
- 支付 1 ,向上爬两个台阶,到达下标为 6 的台阶。
- 支付 1 ,向上爬一个台阶,到达下标为 7 的台阶。
- 支付 1 ,向上爬两个台阶,到达下标为 9 的台阶。
- 支付 1 ,向上爬一个台阶,到达楼梯顶部。
总花费为 6 。

提示:

  • 2 <= cost.length <= 1000
  • 0 <= cost[i] <= 999
算法分析:
确定dp数组及下标含义:

dp[i]表示到达第i阶楼梯所需花费的最小费用。

递推公式:

到第i阶可以从i-1阶跳一步上来,所需花费为dp[i-1]+cost[i-1],也可以从i-2阶跳两步上来,所需花费为dp[i-2]+cost[i-2],所以到达第i阶所需要的最小花费为dp[i]=min(dp[i-1]+cost[i-1],dp[i-2]+cost[i-2])。

初始化:

题目给出的条件,我们可以从第0阶或第1阶楼梯开始爬楼梯。

所以爬上第0阶楼梯所需的最小花费dp[0]=0,爬上第1阶所需的最小花费dp[1]=0;

遍历顺序:

从前往后依次遍历并确定到达每阶楼梯所需的最小花费。

如果有问题打印dp数组验证。

代码如下:

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

时间复杂度o(n),空间复杂度o(n).

总结

解决了这三道题,动态规划算是入门了,这三道题只要按照动规五部曲来还是比较简单的。

动规五部曲:

1,确定dp数组及下标的含义。

2,确定递归公式。

3,初始化。

4,确定遍历顺序。

5,打印dp数组验证结果。

http://www.yayakq.cn/news/304379/

相关文章:

  • wordpress 优秀站点设计图网站
  • 塔式服务器主机建网站官方建设网站
  • 淮北官方网站网页设计网站结构图怎么弄
  • 北京网站设计制作关键词优化微信小程序开发推广大连网站建设开源
  • 手机如何建设网站首页公众号开发者是什么意思
  • 湖南营销型网站建设多少钱银川网站建设一条龙服务
  • 网站一般用什么软件做淮南网站建设科技有限公司
  • 彩票网站和app建设涿州注册公司流程和费用
  • 做视频网站要多大带宽免费微网站案例
  • 网站上传文件夹宁波公司核名网站
  • wordpress站群模板搜附近的人用什么软件
  • 网站制作谁家好可以做基因通路分析的网站
  • 沈阳h5建站请简述网站建设的一般流程图
  • 南宁网站建设流程如何在互联网上做推广
  • 网站首页制作的过程网络机柜定制
  • 全国妇联官方网站儿童之家建设汝城县网站建设公司
  • 专业做网站的公司有没有服务器渭南市住房和城乡建设部网站
  • 个人内网网站建设网站关键字如何设置
  • 余姚企业网站建设建设销售型网站
  • 网站 改域名网站建设与推广范文
  • 郑州定制网站开发手机搭建wordpress 不root
  • 儿童教育自适应网站模板旅行网站建设方案策划书
  • 重庆营销型网站随做的好处国内知名摄影网站
  • 网站关键词书写步骤厦门网站建设推广哪家好
  • 苏州市市政建设集团公司网站网站开发需要什么服务器
  • 自己建个网站多少钱网站建设维护预算
  • 西部数码网站备案核验单做网站用哪个预装系统
  • 小米路由器3做网站二维码生成器在线制作图片
  • 枣庄企业网站推广wordpress4.9 环境
  • 网站站点结构图网页设计师培训费用