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

扁平化设计风格网站wordpress地址和找点地址

扁平化设计风格网站,wordpress地址和找点地址,浙江网站建设推广公司十大排行,合肥网站建设王正刚509. 斐波那契数 力扣题目链接(opens new window) 斐波那契数,通常用 F(n) 表示,形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是: F(0) 0,F(1) 1 F(n) F(n -…

509. 斐波那契数

力扣题目链接(opens new window)

斐波那契数,通常用 F(n) 表示,形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始,后面的每一项数字都是前面两项数字的和。也就是: F(0) = 0,F(1) = 1 F(n) = F(n - 1) + F(n - 2),其中 n > 1 给你n ,请计算 F(n) 。

示例 1:

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

示例 2:

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

示例 3:

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

提示:

  • 0 <= n <= 30

动规五部曲:

这里我们要用一个一维dp数组来保存递归的结果

确定dp数组以及下标的含义

dp[i]的定义为:第i个数的斐波那契数值是dp[i]

确定递推公式

为什么这是一道非常简单的入门题目呢?

因为题目已经把递推公式直接给我们了:状态转移方程 dp[i] = dp[i - 1] + dp[i - 2];

dp数组如何初始化

题目中把如何初始化也直接给我们了,如下:

dp[0] = 0;
dp[1] = 1;

                  

确定遍历顺序

从递归公式dp[i] = dp[i - 1] + dp[i - 2];中可以看出,dp[i]是依赖 dp[i - 1] 和 dp[i - 2],那么遍历的顺序一定是从前到后遍历的

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 index = 2; index <= n; index++){dp[index] = dp[index - 1] + dp[index - 2];}return dp[n];}
}

70. 爬楼梯

力扣题目链接(opens new window)

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

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

注意:给定 n 是一个正整数。

示例 1:

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

示例 2:

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

 例如   第5阶楼梯是第3楼梯+2和第四楼梯加1,所以dp[i]=dp[i-1]+dp[i-2]

那么第一层楼梯再跨两步就到第三层 ,第二层楼梯再跨一步就到第三层。

所以到第三层楼梯的状态可以由第二层楼梯 和 到第一层楼梯状态推导出来,那么就可以想到动态规划了。

 

 746. 使用最小花费爬楼梯

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

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

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

 

dp[i]的定义:到达第i台阶所花费的最少体力为dp[i]。这道题其中 cost[i] 是从楼梯第 i 个台阶向上爬需要支付的费用。所以台阶一共有cost.length+1个

可以有两个途径得到dp[i],一个是dp[i-1] 一个是dp[i-2]

dp[i - 1] 跳到 dp[i] 需要花费 dp[i - 1] + cost[i - 1]。

dp[i - 2] 跳到 dp[i] 需要花费 dp[i - 2] + cost[i - 2]。

那么究竟是选从dp[i - 1]跳还是从dp[i - 2]跳呢?

一定是选最小的,所以dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);

// 方式一:第一步不支付费用
class Solution {public int minCostClimbingStairs(int[] cost) {int len = cost.length;int[] dp = new int[len + 1];// 从下标为 0 或下标为 1 的台阶开始,因此支付费用为0dp[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];}
}
http://www.dtcms.com/wzjs/797352.html

相关文章:

  • 网站建设 服务内容微信怎么做网站推广
  • 湛江做网站seo的济南快速网站排名
  • 建设公司网站需要多少天寻找外贸客户的网站
  • 有哪些网站建设方案西安专业做网站的公司哪家好
  • 直播做ppt的网站邯郸手机网站建设费用
  • 一般建站需要多少钱网站设计公司圣辉友联
  • 荣成住房和城乡建设部网站甘肃省建设厅质量投诉网站
  • 建站之星网站建设下载版苏州市住房和城乡建设局网站首页
  • 人工智能公司网站建设爱企查官网
  • 东莞设计院东莞网站优化建设团队
  • 浮雕模东莞网站建设dede模板蓝色大气简洁企业网站模板
  • 网站锚点怎么用wordpress 统计流量
  • 信息分类网站建设贵州建设厅二建考试网站
  • 浙江网站怎么做推广启动wordpress mu
  • 网站建设用电脑关键词优化技巧有哪些
  • 无障碍 网站 怎么做哪里有网站建设哪家好
  • .net网站开发实站最完整的外贸流程图
  • 网网站站建建站站贵州省贵州省建设厅网站
  • 网站建设买了服务器后怎么做网站做哪些比较赚钱
  • 私人影吧服务器企业seo顾问服务公司
  • 建设完网站成功后需要注意什么问题网站登录流程图
  • 儿童可以做的游戏视频网站久久建筑网站下载
  • 手机上怎么做自己的网站wordpress主机内存
  • 建设部网站监理工程师报名网站建设包括两个方面
  • 淮安网站建设电话100个免费外贸平台
  • 网站由哪些部分组成部分组成部分影视app搭建教程
  • node.js 网站开发wordpress模板如何修改
  • 网站推广策略含义wordpress+学校模版
  • 可以免费发布信息的网站有哪些计算机网络网站建设的实训总结6
  • 天翼云主机 网站mvc做的网站怎么连接数据库