爬楼梯
假设你正在爬楼梯。需要 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[i]:i阶台阶有dp[i]种方法
dp[i]=dp[i-1]+dp[i-2]
class Solution: def climbStairs(self, n: int) -> int: dp=[0]*50 dp[1],dp[2]=1,2 for i in range(3,n+1): dp[i]=dp[i-1]+dp[i-2] return dp[n]
杨辉三角
给定一个非负整数 numRows,生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中,每个数是它左上方和右上方的数的和。 示例 1: 输入: numRows = 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]] 示例 2: 输入: numRows = 1 输出: [[1]] 提示: 1 <= numRows <= 30
class Solution: def generate(self, numRows: int) -> List[List[int]]: dp=[[1]] for i in range(1,numRows): temp=[1] for j in range(1,len(dp[i-1])): temp.append(dp[i-1][j]+dp[i-1][j-1]) temp.append(1) dp.append(temp) return dp
链接:119. 杨辉三角 II - 力扣(LeetCode)
输出杨辉三角第i行
class Solution: def getRow(self, rowIndex: int) -> List[int]: dp=[[1]] for i in range(1,rowIndex+1): temp=[1] for j in range(1,len(dp[i-1])): temp.append(dp[i-1][j]+dp[i-1][j-1]) temp.append(1) dp.append(temp) return dp[rowIndex]
买卖股票的最佳时机
链接:121. 买卖股票的最佳时机 - 力扣(LeetCode)
给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易中获取的最大利润。如果你不能获取任何利润,返回 0 。 示例 1: 输入:[7,1,5,3,6,4] 输出:5 解释:在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。 注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格;同时,你不能在买入前卖出股票。 示例 2: 输入:prices = [7,6,4,3,1] 输出:0 解释:在这种情况下, 没有交易完成, 所以最大利润为 0。 提示: 1 <= prices.length <= 105 0 <= prices[i] <= 104
dp[i][0]:第i天买花最小前,dp[i][1]:第i天卖的最佳价值
class Solution: def maxProfit(self, prices: List[int]) -> int: dp=[[0,0] for i in range(len(prices))] dp[0][0]=0-prices[0] for i in range(1,len(prices)): dp[i][0]=max(0-prices[i],dp[i-1][0]) dp[i][1]=max(prices[i]+dp[i-1][0],dp[i-1][1]) return dp[len(prices)-1][1]
标签:temp,int,杨辉三角,range,prices,动态,Leetcode,dp,刷题 From: https://www.cnblogs.com/xiaoruru/p/18077670