data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
g0101_0200.s0134_gas_station.Solution.kt Maven / Gradle / Ivy
package g0101_0200.s0134_gas_station
// #Medium #Top_Interview_Questions #Array #Greedy
// #2022_10_09_Time_545_ms_(70.18%)_Space_74.6_MB_(45.61%)
class Solution {
fun canCompleteCircuit(gas: IntArray, cost: IntArray): Int {
var sumGas = 0
var sumCost = 0
var curGas = 0
var result = -1
for (i in gas.indices) {
curGas += gas[i] - cost[i]
// re-calculate the starting point
if (curGas < 0) {
result = -1
curGas = 0
} else if (result == -1) {
// set initial starting point
result = i
}
sumGas += gas[i]
sumCost += cost[i]
}
return if (sumGas < sumCost) {
-1
} else result
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy