当前位置:   article > 正文

[leetcode] 134 Gas Station(经典dp || 贪心)_gas station贪心法

gas station贪心法

(一)最容易想到的是O(n2)的解法

预处理出gas[i] - cost[i] 的数组,从每个非负的位置开始尝试,只要能够完成一个循环,就可以输出结果;

对于返回-1的情况,我们经过思考和推论可以得出:对于一个循环数组,如果这个数组整体和 SUM >= 0,那么必然可以在数组中找到这么一个元素:从这个数组元素出发,绕数组一圈,能保证累加和一直是出于非负状态。

所以只需要比较sum和0的大小就可以判断是否有解。

(二)继续对问题进行抽象,我们肯定希望一开始的路程都是加油>消耗的,这样就可以累积油量应付后面的消耗量大的,根据这个思路,就转变成求数组的最大连续子序列的和(并且记录起始下标),这是我们前面接触过的题目,例如hdu 1003;

但是因为是循环数组,我们还得考虑一种情况:就是首尾都是正数,怎么办呢?我们只需要再记录并求得  最小连续子序列的和就可以了,最后取Maxsum和sum-Minsum的最大值。另外Minsum的小标要加一取余返回。

  1. class Solution {
  2. public:
  3. int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
  4. int sum=0;
  5. for(int i=0;i<gas.size();i++)
  6. {
  7. gas[i]=gas[i]-cost[i];
  8. sum+=gas[i];
  9. }
  10. if(sum<0)
  11. return -1;
  12. int tot1=0,tot2=0;
  13. int Maxsum=gas[0],Minsum=gas[0];
  14. int Maxpos=0,CurMaxp=0,Minpos=0;
  15. for(int i=0;i<gas.size();i++)
  16. {
  17. if(tot1+gas[i]<gas[i]) //最大连续子序列和
  18. {
  19. tot1=gas[i];
  20. CurMaxp=i;
  21. }
  22. else
  23. tot1+=gas[i];
  24. if(tot1>Maxsum)
  25. {
  26. Maxsum=tot1;
  27. Maxpos=CurMaxp;
  28. }
  29. if(tot2+gas[i]>gas[i])//最小连续子序列和
  30. tot2=gas[i];
  31. else
  32. tot2+=gas[i];
  33. if(tot2<Minsum)
  34. {
  35. Minsum=tot2;
  36. Minpos=i;
  37. }
  38. }
  39. if(Maxsum>=(sum-Minsum))
  40. return Maxpos;
  41. else
  42. return (Minpos+1)%gas.size();
  43. }
  44. };
(三)还有另外一种简单的思路。我们首先从i站点出发,若走到当前站点cur我们的油量<0,那么只需要从cur+1继续出发试探即可。在此不进行证明,但是我们可以宏观的想一下,前面的任意的前缀站点段的油量和肯定是>0的,那么去掉任意一个前缀,只会使油量变得更少,所以我们只能尝试从cur+1重新开始。

  1. class Solution {
  2. public:
  3. int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
  4. int sum=0;
  5. for(int i=0;i<gas.size();i++)
  6. {
  7. gas[i]=gas[i]-cost[i];
  8. sum+=gas[i];
  9. }
  10. if(sum<0)
  11. return -1;
  12. int ans=0,tot=0;
  13. for(int i=0;i<gas.size();i++)
  14. {
  15. tot+=gas[i];
  16. if(tot<0)
  17. {
  18. ans=i+1;
  19. tot=0;
  20. }
  21. }
  22. return ans;
  23. }
  24. };



声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/493504
推荐阅读
相关标签
  

闽ICP备14008679号