贪心算法part02
LC122买卖股票的最佳时机II(未掌握)
- 未掌握原因分析:对贪心思维转换不过来
- 思路:最终利润是可以分解的
- 第 0 天买入,第 3 天卖出,那么利润为:prices[3] - prices[0]
- 利润可以分解为(prices[3] - prices[2]) + (prices[2] - prices[1]) + (prices[1] - prices[0])
- 把利润分解为每天为单位的维度,而不是从 0 天到第 3 天整体去考虑,追求每天利润的最大化
- 然后收集正利润的和即是最大利润值
LC55跳跃游戏(贪心算法未掌握)
- dp思路:倒序,如果dp[i]之后的nums[i]个dp数值中存在能够到达最后一个下标的数值,则i位置也可以到达
- 代码
- 贪心思路:其实每个位置跳几步无所谓,关键在于可跳的覆盖范围,只要每一步的都更新最大范围并且最大范围可以覆盖到终点就说明是可以移动到终点的。
- 定义for循环,i只能在cover中移动
- 代码
LC45跳跃游戏II(未掌握)
- 贪心思路:
- 从覆盖范围出发,不管怎么跳,覆盖范围内一定是可以跳到的,以最小的步数增加覆盖范围,覆盖范围一旦覆盖了终点,得到的就是最少步数
- 移动下标达到了当前覆盖的最远距离下标时,步数就要加一,来增加覆盖距离。最后的步数就是最少步数。
- 代码