当前位置: 首页 > news >正文

申请建设网站的请示在百度上打广告找谁

申请建设网站的请示,在百度上打广告找谁,做幼儿手工网站,广州站长题目: 链接:LeetCode 134. 加油站 难度:中等 在一条环路上有 n 个加油站,其中第 i 个加油站有汽油 gas[i] 升。 你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i1 个加油站需要消耗汽油 cost[i] 升。你从其中…

题目:

链接:LeetCode 134. 加油站
难度:中等

在一条环路上有 n 个加油站,其中第 i 个加油站有汽油 gas[i] 升。

你有一辆油箱容量无限的的汽车,从第 i 个加油站开往第 i+1 个加油站需要消耗汽油 cost[i] 升。你从其中的一个加油站出发,开始时油箱为空。

给定两个整数数组 gas 和 cost ,如果你可以绕环路行驶一周,则返回出发时加油站的编号,否则返回 -1 。如果存在解,则 保证 它是 唯一 的。

示例 1:

输入: gas = [1,2,3,4,5], cost = [3,4,5,1,2]
输出: 3
解释:
从 3 号加油站(索引为 3 处)出发,可获得 4 升汽油。此时油箱有 = 0 + 4 = 4 升汽油
开往 4 号加油站,此时油箱有 4 - 1 + 5 = 8 升汽油
开往 0 号加油站,此时油箱有 8 - 2 + 1 = 7 升汽油
开往 1 号加油站,此时油箱有 7 - 3 + 2 = 6 升汽油
开往 2 号加油站,此时油箱有 6 - 4 + 3 = 5 升汽油
开往 3 号加油站,你需要消耗 5 升汽油,正好足够你返回到 3 号加油站。
因此,3 可为起始索引。

示例 2:

输入: gas = [2,3,4], cost = [3,4,3]
输出: -1
解释:
你不能从 0 号或 1 号加油站出发,因为没有足够的汽油可以让你行驶到下一个加油站。
我们从 2 号加油站出发,可以获得 4 升汽油。 此时油箱有 = 0 + 4 = 4 升汽油
开往 0 号加油站,此时油箱有 4 - 3 + 2 = 3 升汽油
开往 1 号加油站,此时油箱有 3 - 3 + 3 = 3 升汽油
你无法返回 2 号加油站,因为返程需要消耗 4 升汽油,但是你的油箱只有 3 升汽油。
因此,无论怎样,你都不可能绕环路行驶一周。

提示:

  • gas.length == n
  • cost.length == n
  • 1 <= n <= 105
  • 0 <= gas[i], cost[i] <= 104

方法一:

函数图像法:

在这里插入图片描述
sum 代表路途中油箱的油量,如果把这个「最低点」作为起点,即把这个点作为坐标轴原点,就相当于把图像「最大限度」向上平移了:
在这里插入图片描述
如果经过平移后图像全部在 x 轴以上,就说明可以行使一周。

代码一:

class Solution {
public:int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {int n = gas.size();int minsum = 0, minpos = 0; //函数最低点的值,函数最低点的坐标(出发站编号)int sum = 0;for(int i = 0; i < n; i++){sum += gas[i] - cost[i];if(sum < minsum) {minsum = sum;minpos = i + 1;}}if(sum < 0) return -1;return minpos % n;}
};

时间复杂度O(n),空间复杂度O(1)。

方法二:

贪心解法:

用贪心思路解决这道题的关键在于以下这个结论:

如果选择站点i作为起点「恰好」无法走到站点j,那么i和j中间的任意站点k都不可能作为起点。

比如说,如果从站点1出发,走到站点5时油箱中的油量「恰好」减到了负数,那么说明站点1「恰好」无法到达站点5;那么你从站点2,3,4任意一个站点出发都无法到达5,因为到达站点5时油箱的油量也必然被减到负数。

如何证明这个结论?

假设sum记录当前油箱中的油量,如果从站点i出发(sum = 0),走到j时恰好出现sum < 0的情况,那说明走到i, j之间的任意站点k时都满足sum > 0,对吧。

如果把k作为起点的话,相当于在站点k时sum = 0,那走到j时必然有sum < 0,也就是说k肯定不能是起点。

拜托,从i出发走到k好歹sum > 0,都无法达到j,现在你还让sum = 0了,那更不可能走到j了对吧。

综上,这个结论就被证明了。

回想一下我们开头说的暴力解法是怎么做的?

如果我发现从i出发无法走到j,那么显然i不可能是起点。

现在,我们发现了一个新规律,可以推导出什么?

如果我发现从i出发无法走到j,那么i以及i, j之间的所有站点都不可能作为起点。

看到冗余计算了吗?看到优化的点了吗?

这就是贪心思路的本质,如果找不到重复计算,那就通过问题中一些隐藏较深的规律,来减少冗余计算。

代码二:

class Solution {
public:int canCompleteCircuit(vector<int>& gas, vector<int>& cost) {int n = gas.size();for(int i = 0; i < n;){int sum = 0;bool flag = true; //以i为出发站时能否环行一周for(int j = i; j < i + n; j++){sum += gas[j % n] - cost[j % n]; //行至第j+1个加油站时,油箱内的油量if(sum < 0) {if(j + 1 >= n) return -1; //全部出发点已遍历完,未找到可行解i = (j + 1) % n; //无法从第i站到第j+1站,则从中间任意一站都无法到第j+1站。那么以第j+1站为出发站继续检查flag = false;break;}}if(flag) return i; //以第i站为出发站可以走完一周,返回i}return -1;}
};

时间复杂度O(n),空间复杂度O(1)。

http://www.fp688.cn/news/152991.html

相关文章:

  • 做网站的类型网站功能
  • 2015帝国cms网站蔡甸seo排名公司
  • mvc5 web网站开发实战产品推广策略怎么写
  • 简约网站模板新疆疫情最新情况
  • 企业网站优化网络营销案例分析
  • 怎么改网站域名网络营销毕业论文范文
  • 龙华企业网站建设公司福州网站seo公司
  • 手机站制作的网站架构百度一下你就知道手机版
  • 网站备案是什么意思怎么建立一个属于自己的网站
  • 网店推广工作内容网站优化+山东
  • 百业网免费发布信息seo如何挖掘关键词
  • 宣传片拍摄合同交印花税吗深圳百度seo优化
  • 网站备案需要关闭seo百度seo排名优化软件
  • 微芒网站建设友情链接互换
  • 音平商城谁做的网站seo优化器
  • 手机网站导航栏特效房地产估价师考试
  • 重庆网站建站推广广州网络营销运营
  • wordpress这么安装不了漯河seo公司
  • 中国建设教育协会的官方网站厦门谷歌seo
  • 门户型网站建设免费营销培训
  • 网站建设外包发展情况网络销售网站
  • 网站建设的一般要素网络营销相关的岗位有哪些
  • 做网站需要多少钱 百度搜狗搜索引擎推广
  • 专注于上海seo做网站建设雅虎日本新闻
  • 找别人做网站注意什么临沂百度公司地址
  • 大连网站搜索排名提升东莞seo外包公司哪家好
  • 网站开发实验心得设计网站官网
  • 怎样给网站做深圳龙岗区疫情最新消息
  • java做手机网站建设建网站软件工具
  • 做企业平台网站成本官网优化包括什么内容