贪心的思路,局部最优:让绝对值大的负数变为正数,当前数值达到最大,整体最优:整个数组和达到最大。局部最优可以推出全局最优。那么如果将负数都转变为正数了,K依然大于0,此时的问题是一个有序正整数序列,如何转变K次正负,让数组和达到最大。那么又是一个贪心:局部最优:只找数值最小的正整数进行反转,当前数值和可以达到最(例如正整数数组{5, 3, 1},反转1得到-1比反转5得到的-5大多了),全局最优:整个数组和达到最大。代码如下:
暴力的方法很明显就是O(n^2)的,遍历每一个加油站为起点的情况,模拟一圈。如果跑了一圈,中途没有断油,而且最后油量大于等于0,说明这个起点是ok的。暴力的方法思路比较简单,但代码写起来也不是很容易,关键是要模拟跑一圈的过程。for循环适合模拟从头到尾的遍历,而while循环适合模拟环形遍历,要善于使用while!代码如下:
-
LeetCode 135. 分发糖果
这道题目是要确定一边之后,再确定另一边,例如比较每一个孩子的左边,然后再比较右边。先确定右边评分大于左边的情况(也就是从前向后遍历)。此时局部最优:只要右边评分比左边大,右边的孩子就多一个糖果,全局最优:相邻的孩子中,评分高的右孩子获得比左边孩子更多的糖果局部最优可以推出全局最优。代码如下: