leetcode746-Min Cost Climbing Stairs

题目

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

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

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

示例 1:

输入:cost = [10,15,20]

输出:15

解释:你将从下标为 1 的台阶开始。

  • 支付 15 ,向上爬两个台阶,到达楼梯顶部。
    总花费为 15 。

分析

这道题目很明显用动态规划的思路。我们可以定义dp[i]为到达第i层楼梯所支付的最小费用,如果要往上爬则要叠加当前楼层的费用。接下来看如何推倒dp,因为可以通过2个台阶或者1个台阶的方式到达,所以要么是dp[i-2]+cost[i-2],要么是dp[i-1]+cost[i-1],且俩个里面取最小值

java 复制代码
public class minCostClimbingStairs {
	public static void main(String[] args) {
		int[] arr ={1,100,1,1,1,100,1,1,100,1};
		System.out.println(minCost(arr));
	}
	public static int minCost(int[] arr) {
		int len = arr.length;
		int[] dp = new int[len+1];
		for(int i = 2;i<=len;i++) {
			dp[i] = Math.min(dp[i-2]+arr[i-2],dp[i-1]+arr[i-1]);
		}
		return dp[len];
	}
}
l
相关推荐
MacroZheng2 小时前
堪称一站式管理平台,同时支持Linux、MySQL、Redis、MongoDB可视化管理!
java·linux·后端
anlogic2 小时前
Java基础 9.10
java·开发语言·算法
SimonKing2 小时前
数据库又慢了?你需要一个像样的慢SQL报警系统
java·后端·程序员
薛定谔的算法2 小时前
JavaScript单链表实现详解:从基础到实践
数据结构·算法·leetcode
yongche_shi2 小时前
第二篇:Python“装包”与“拆包”的艺术:可迭代对象、迭代器、生成器
开发语言·python·面试·面试宝典·生成器·拆包·装包
Developer-YC2 小时前
像素图生成小程序开发全解析:从图片上传到Excel图纸
java·javascript·图像处理·微信小程序·excel
CoovallyAIHub2 小时前
CostFilter-AD:用“匹配代价过滤”刷新工业质检异常检测新高度! (附论文和源码)
深度学习·算法·计算机视觉
幻奏岚音2 小时前
《数据库系统概论》第一章 初识数据库
数据库·算法·oracle
AAA修煤气灶刘哥2 小时前
别懵!从单机锁到 Redisson,分布式锁的坑我全帮你填了
java·redis·spring cloud
你好,我叫C小白2 小时前
贪心算法(最优装载问题)
算法·贪心算法·最优装载问题