[Leetcode]134.加油站
这一题是贪心不是模拟 是贪心不是模拟 是贪心不是模拟!
如果用模拟的做法会比较慢,也失去了做这一题的趣味了。
模拟的方法很简单,就是每一个加油站都做起点模拟一遍,试一下能不能完成一圈,能完成一圈就保存答案,不能完成的就往下一个找
如果都不能完成则返回-1
贪心的做法非常的巧妙,整个循环数组如下性质。
对于一个循环数组,如果这个数组整体和 >= 0,那么必然可以在数组中找到这么一个元素:从这个数组元素出发,绕数组一圈,能保证累加和一直是出于非负状态。
这个需要用集合的方法证明:
循环数组分成两个必存在一个区间二分,使得{区间1的和}>0 且{区间1的和}>=abs{区间2的和}。
我们只要从这个找到的区间1的起始位置出发,必然能累加和处于非负状态。
注释中有讲解如何处理一些细节的问题。
class Solution {
public:
    int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {
        int n=gas.size();
        int j=-;
        int sum=,total=;
        for(int i=;i<n;i++){
            sum+=gas[i]-cost[i];
            total+=gas[i]-cost[i];
            if(sum<){
                /*说明之前的油不能支撑到这个加油站,之前的加油站都不能作为起点*/
                sum=;
                /*重置为0*/
                j=i;
                /*将此加油站后一点设为起点再寻找*/
            }
        }
        /*先判断total是否小于0,小于0说明找不到这个起始点*/
        if(total<)return -;
        else return j+;
    }
};
[Leetcode]134.加油站的更多相关文章
- leetcode 134 加油站问题
		leetcode 134 解析 在一条环路上有 N 个加油站,其中第 i 个加油站有汽油 gas[i] 升. 你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 co ... 
- Java实现 LeetCode 134 加油站
		134. 加油站 在一条环路上有 N 个加油站,其中第 i 个加油站有汽油 gas[i] 升. 你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升 ... 
- LeetCode 134. 加油站(Gas Station)
		题目描述 在一条环路上有 N 个加油站,其中第 i 个加油站有汽油 gas[i] 升. 你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升.你从其 ... 
- LeetCode:加油站【134】
		LeetCode:加油站[134] 题目描述 在一条环路上有 N 个加油站,其中第 i 个加油站有汽油 gas[i] 升. 你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要 ... 
- [Leetcode 134]汽车加油站 Gas Station (环形)
		[题目] There are N gas stations along a circular route, where the amount of gas at station i is gas[i] ... 
- [leetcode]134. Gas Station加油站
		There are N gas stations along a circular route, where the amount of gas at station i is gas[i]. Y ... 
- [LeetCode] 134. Gas Station 解题思路
		There are N gas stations along a circular route, where the amount of gas at station i is gas[i]. You ... 
- Leetcode 134 Gas Station
		There are N gas stations along a circular route, where the amount of gas at station i is gas[i]. You ... 
- leetcode@ [134] Gas station (Dynamic Programming)
		https://leetcode.com/problems/gas-station/ 题目: There are N gas stations along a circular route, wher ... 
随机推荐
- vue 开发系列(一) vue 开发环境搭建
			概要 目前前端开发技术越来越像后台开发了,有一站式的解决方案. 1.JS包的依赖管理像MAVEN. 2.JS代码编译打包. 3.组件式的开发. vue 是一个前端的一站式的前端解决方案,从项目的初始化 ... 
- C++ 中 new 操作符内幕:new operator、operator new、placement new
			一.new 操作符(new operator) 人们有时好像喜欢有益使C++语言的术语难以理解.比方说new操作符(new operator)和operator new的差别. 当你写这种代码: st ... 
- c# devexpress绘图 三角函数
			加标题: using System; using System.Windows.Forms; using DevExpress.XtraCharts; // ... namespace SideByS ... 
- BZOJ 4765 普通计算姬 (分块 + BIT)
			4765: 普通计算姬 Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 1547 Solved: 329[Submit][Status][Discus ... 
- 泡泡机器人SLAM 2019
			LDSO:具有回环检测的直接稀疏里程计:LDSO:Direct Sparse Odometry with Loop Closure Abstract—In this paper we present ... 
- CentOS 5.8下快速搭建FTP服务器
			学习安装和配置vsftpd: 实验环境:CentOS 5.8 x86_64 测试环境关掉防火墙和selinux. service iptables stop setenforce 0 1.安装vsft ... 
- POJ2385--Apple Catching(动态规划)
			It is a little known fact that cows love apples. Farmer John has two apple trees (which are convenie ... 
- 1、从C语言到C++
			1.面向对象的C++ c++是在C语言的基础上发展起来的一门语言,C++是即支持结构化程序编程又支持面向对象程序设计的混合型语言.他一方面提供了对C的兼容性,保持了C的简介.高效,接近汇编语言的特点, ... 
- 万能头文件#include <bits/stdc++.h>
			最近在做题的时候看到别人的题解发现别人都用这个 突然之间打开新世界的大门 去百度之后才知道#include <bits/stdc++.h>包含了目前所有的c++头文件 也就是说只要用#in ... 
- html,css,jquery,JavaScript
			1.全选 (当点击checkall按钮时,选中所有checkbox用prop全选上)function checkAll() { $(':checkbox').prop('checked', true) ... 
