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

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

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

我觉得我的思路很笨 就是找到第一个可以往下走的 如果可以顺利的话 那么就OK 如果不顺利 那么就继续往下找 因为解是唯一的 所以只要找到直接return就行 虽然不确定是不是会超过时间限制 但是还是先试一下

我的大体思路就是:我往下找 找到第一个满足的 就开始计算步数和余量 只要往下走就往下走 步数要走到n才行  计算此时的索引就使用取模的方法 如果到了什么时候rem<0 那么就break 不然就step+=1 如果等于n了 那么就return i (反正要么就是while结束了 要么就是break了) 如果并没有return i 那么就证明是这个不行 那要继续往下选择

那么重点来了 我要使用i+1吗?显然不是 因为我走了step步之后无法走下去 那么选择i和i+step中间的是可以保证走下去的吗?

跳过失败路径中的所有站点是贪心算法的关键优化点之一,它能将时间复杂度从 O(n²) 降到 O(n)。这不是因为“某一步负数太多”,而是因为整个路径的净收益是负的,意味着从任何子起点都无法完成一圈。所以继续进行的就是i+step+1

但是我领会到其中的奥妙了 你想啊 我从中间的出发 根本到不了下一步 为什么? 我既然是走到这步才停 证明是因为前面的是有剩余的 到我这步又亏损了 亏损大了 才到不了 那你可能会觉得 诶 那我从亏损超级大的那一步往下走到不了吗?你想啊 你既然是从亏损超级大的那一步往下走 既然可以往下走 就证明有剩余 有剩余都走不到这个step步 那中间的哪一个都不行(因为要想到达中间的某一步 任何一步 都是要有结余的 有结余还不行 那么我从头开始更不行)我少了前面的补贴 还要面对后面的亏损 达咩达咩

好的来看代码

class Solution(object):def canCompleteCircuit(self, gas, cost):i=0index=-1n=len(gas)while i <n:#如果当前的汽油不够消耗到下一步的 就继续往下找if gas[i]<cost[i]:i+=1continue#如果找到了这一个gas = [1,2,3,4,5], cost = [3,4,5,1,2]#现在是索引为3的地方 那么要是继续往下走 就要满足gas-cost+gas>=cost#计算剩余量和步数rem=0step=0while step<n:j = (i + step) % nrem += gas[j] - cost[j]if rem < 0:breakstep += 1if step==n:return i#证明这个i是不行的 那么我是需要走i+1的这一步的吗?#不是的 因为我从i开始可以的 证明我i这步是有盈余的 既然走到这步不行了#那么就证明无论我从中间的哪一步开始 走到这步肯定都不行了 所以要跨过step这个步骤开始else:i=step+i+1return -1
solution=Solution()
result=solution.canCompleteCircuit([2,3,4], [3,4,3])
print(result)

但是这个运行速度只超过百分之三十多 所以我们来分析一下排名第一的代码

首先就是计算总和 如果消耗总和大于油量总和 那直接不行 

然后就是直接计算盈余 一旦盈余小于0 改变开始的索引? 感觉这个for循环写的还是挺深奥的 如果小于0的话 证明这个起点不行 那么是尝试下一个这个我明白 但是为什么直接每个点开始计算结余呢?从第一个点开始 如果这个剩余小于0 那这个点不行 使用i+1这个点 如果是大于0的 那么这个点就不变 i继续往下走 在这个过程中 只要这个剩余小于0 就证明这个包括这个中间的点都是不行的 (看我上面的解释) 喵喵喵啊

class Solution(object):def canCompleteCircuit(self, gas, cost):""":type gas: List[int]:type cost: List[int]:rtype: int"""if sum(gas) < sum(cost):return -1cursum = 0start_idx = 0for i in range(len(gas)):cursum += gas[i] - cost[i]if cursum < 0:start_idx = i + 1cursum = 0return start_idx

如果喜欢这个帖子 欢迎点赞收藏!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/92440.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/92440.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/92440.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python + Pika RabbitMQ集群压测完整方案

一、最近搭建了个rabbitmq集群 三个磁盘节点&#xff0c;上生产环境之前想做个压测&#xff0c;测试下稳定性&#xff0c;参考Deepseek做了如下测试方案二、核心代码实现&#xff1a; 配置文件 (config.py) import os RABBITMQ_NODES [amqp://admin:123456192.168.0.175:8101,…

【第7话:相机模型3】自动驾驶IPM图像投影拼接技术详解及代码示例

IPM图像投影拼接技术详解 IPM&#xff08;逆透视映射&#xff09;图像投影拼接技术是一种在计算机视觉中广泛应用的图像处理方法&#xff0c;主要用于将多个透视视图的图像转换为鸟瞰视图并拼接成一个无缝的大场景图像。该技术特别适用于自动驾驶、机器人导航和监控系统等领域&…

【测试工程思考】测试自动化基础能力建设

1 回顾 传统软件研发体系下定义的软件测试是从用户视角设计的。测试是试图穷尽用户行为的工程&#xff0c;从测试用例&#xff08;use case&#xff09;的英文定义就可见一般。测试的逻辑资产就是用自然语言去描述用户的操作行为或路径。 但随着软件工程向分布式架构和敏捷交付…

进阶向:AI聊天机器人(NLP+DeepSeek API)

什么是AI聊天机器人? AI聊天机器人是一种通过自然语言处理(NLP)技术模拟人类对话的智能程序系统。其核心是建立在机器学习算法和大型语言模型基础上的对话引擎,能够理解用户的自然语言输入,分析语境和意图,并生成符合上下文的相关回复。 这类机器人系统通常包含以下几个…

一个C#的段子

猜猜按钮的结果是啥。 public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void Form1_Load(object sender, EventArgs e) { } public static bool flag true; privat…

使用 gptqmodel 量化 Qwen3-Coder-30B-A3B-Instruct

代码部分 : quantize_qwen3_coder_30b_a3b_instruct_gptq.py import os########## 环境变量设置 ########## # 当前可用的 CUDA 编号 os.environ["CUDA_VISIBLE_DEVICES"] "1" # GPU 显存资源片段优化 os.environ["PYTORCH_CUDA_ALLOC_CONF"] …

基于python、django的疫苗接种管理系统

基于python、django的疫苗接种管理系统

Go语言实战案例:使用sync.Map构建线程安全map

在并发编程中&#xff0c;共享资源的访问是一个绕不开的问题。Go 中的 map 在并发读写时是不安全的&#xff0c;直接使用可能导致程序 panic。因此&#xff0c;在多协程同时访问 Map 的场景下&#xff0c;必须采取有效的同步措施。本篇将通过一个实战案例&#xff0c;介绍 Go 的…

关于vue2中对接海康摄像头以及直播流rtsp或rtmp,后台ffmpeg转码后通过ws实现

最近项目中需要对接摄像头监控&#xff0c;海康摄像头为rtsp流格式有一个软件VLC media player&#xff0c;可以在线进行rtsp或者rtmp流播放&#xff0c;可用来测试流地址是否可用功能实现思路为后台通过fmpeg把rtsp流进行转码&#xff0c;然后通过ws方式进行一帧一帧推送。&am…

Docker容器强制删除及文件系统修复完整指南

Docker容器强制删除及文件系统修复完整指南 故障现象与原因分析 ​故障表现​&#xff1a; ERROR: for c9ca40be974d_OpIsosMD_OB unable to remove filesystem unlinkat /data/docker/storage/containers/c9ca40be974d...: structure needs cleaning​根本原因​&#xff1a;…

Matplotlib 知识点总结

1. 基础绘图&#xff08;plot函数&#xff09;基本语法&#xff1a;plot([x], y, [fmt], [x2], y2, [fmt2], ..., **kwargs)功能特点&#xff1a;可绘制点、线和组合图形自动生成x轴&#xff08;0-N-1&#xff09;当x未指定时示例&#xff1a;绘制两点连线、多点不规则线等代码…

高可用微服务架构实战:Nacos集群+Nginx负载均衡,Spring Cloud无缝对接

"当你的注册中心挂了&#xff0c;整个微服务就变成了无头苍蝇。" 这是我在生产环境踩坑后最痛的领悟。今天&#xff0c;我将分享如何用Nacos集群Nginx搭建坚如磐石的注册中心&#xff0c;让你的微服务永不迷路&#xff01; 在 Windows 环境下配置 Nacos 集群&#x…

Spark大数据处理实战指南

Spark 简介 Apache Spark 是一个开源的分布式计算框架,专为大规模数据处理而设计。它通过内存计算和优化的执行引擎显著提升了数据处理速度,适用于批处理、实时流处理、机器学习和图计算等场景。 核心特性 高性能:利用内存计算(In-Memory Processing)减少磁盘 I/O,比传…

浏览器缓存机制全解析:强缓存与协商缓存

浏览器缓存是浏览器为提升页面加载速度、减少服务器压力和节省网络带宽&#xff0c;在本地存储资源&#xff08;如 HTML、CSS、JS、图片等&#xff09;的机制。其核心分为强缓存和协商缓存&#xff0c;并涉及多种 HTTP 头字段和存储位置。以下是详细解析&#xff1a;⚙️ 一、缓…

知识随记-----Qt 实用技巧:自定义倒计时按钮防止用户频繁点击

Qt 技巧&#xff1a;实现自定义倒计时按钮防止用户频繁点击注册 项目场景 在一个基于 Qt 开发的聊天应用中&#xff0c;用户注册时需要获取验证码。为防止用户频繁点击获取验证码按钮&#xff0c;需要实现一个倒计时功能&#xff0c;用户点击后按钮进入倒计时状态&#xff0c;倒…

Linux与Windows应急响应

本人首先进行了linux的应急响应&#xff0c;windows之后再进行 Linux与Windows应急响应初体验1 linux应急响应1.1 账户&#xff1a;1.1.1 使用cat /etc/passwd命令查看passwd文件2.1.2 使用cat /etc/shadow命令查找shadow文件&#xff0c;该文件为密码文件的存储项1.2 入侵排查…

计算机网络1-4:计算机网络的定义和分类

目录 计算机网络的定义 计算机网络的分类 计算机网络的定义 计算机网络的分类 按交换技术分类&#xff1a;电路交换网络、报文交换网络、分组交换网络 按使用者分类&#xff1a;公用网、专用网 按传输介质分类&#xff1a;有线网络、无线网络 按覆盖范围分类&#xff1a;…

在QT中动态添加/删除控件,伸缩因子该怎么处理

开发中遇到的问题[TOC](开发中遇到的问题)处理方式在我们的界面开发过程中&#xff0c;通常需要开发一些可以动态添加or删除控件的容器&#xff0c;类似Tab页一样&#xff0c;为了美观的话&#xff0c;我们通常使用伸缩因子将容器中的控件往一个方向挤&#xff0c;类似下面的控…

【设计模式精解】什么是代理模式?彻底理解静态代理和动态代理

目录 静态代理 动态代理 JDK动态代理 CGLIB代理 JDK动态代理和CGLIB代理的区别 总结 代理模式简单来说就是 我们使用代理对象来代替对真实对象(real object)的访问&#xff0c;这样就可以在不修改原目标对象的前提下&#xff0c;扩展目标对象的功能。 代理模式有静态代理…

MCU AI/ML - 弥合智能和嵌入式系统之间的差距

作者&#xff1a;芯科科技产品营销高级经理Gopinath Krishniah 人工智能&#xff08;AI&#xff09;和机器学习&#xff08;ML&#xff09;是使系统能够从数据中学习、进行推理并随着时间的推移提高性能的关键技术。这些技术通常用于大型数据中心和功能强大的GPU&#xff0c;但…