Форум программистов, компьютерный форум, киберфорум
alhaos
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  

[golang] 134. Gas Station

Запись от alhaos размещена 17.02.2025 в 18:49
Показов 1798 Комментарии 0
Метки go, problem

Тут нам даны два целочисленных слайса gas и cost, индексы массива представляют собой заправочные станции. а элементы gas это количество топлива на такой станции, cost это количество топлива необходимое для того чтобы добраться до следующей станции, станции закольцованы, движений по часовой стрелке.

Гарантируется, что во всех тестовых данные если присутствует путь возможного обхода то он единственный.

Необходимо вернуть индекс элемента с которого можно объехать все станции. Если такого элемента нет необходимо вернуть -1.

Go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
// [url]https://leetcode.com/studyplan/top-interview-150/[/url]
 
package topInterview
 
// 134. Gas Station
// There are n gas stations along a circular route, where the amount of gas at the ith station is gas[i].
// 
// You have a car with an unlimited gas tank and it costs cost[i] of gas to travel from the ith station to its next (i + 1)th station. You begin the journey with an empty tank at one of the gas stations.
// 
// Given two integer arrays gas and cost, return the starting gas station's index if you can travel around the circuit once in the clockwise direction, otherwise return -1. If there exists a  solution, it is guaranteed to be unique.
// 
//  
// 
// Example 1:
// 
// Input: gas = [1,2,3,4,5], cost = [3,4,5,1,2]
// Output: 3
// Explanation:
// Start at station 3 (index 3) and fill up with 4 unit of gas. Your tank = 0 + 4 = 4
// Travel to station 4. Your tank = 4 - 1 + 5 = 8
// Travel to station 0. Your tank = 8 - 2 + 1 = 7
// Travel to station 1. Your tank = 7 - 3 + 2 = 6
// Travel to station 2. Your tank = 6 - 4 + 3 = 5
// Travel to station 3. The cost is 5. Your gas is just enough to travel back to station 3.
// Therefore, return 3 as the starting index.
// Example 2:
// 
// Input: gas = [2,3,4], cost = [3,4,3]
// Output: -1
// Explanation:
// You can't start at station 0 or 1, as there is not enough gas to travel to the next station.
// Let's start at station 2 and fill up with 4 unit of gas. Your tank = 0 + 4 = 4
// Travel to station 0. Your tank = 4 - 3 + 2 = 3
// Travel to station 1. Your tank = 3 - 3 + 3 = 3
// You cannot travel back to station 2, as it requires 4 unit of gas but you only have 3.
// Therefore, you can't travel around the circuit once no matter where you start.
//  
// 
// Constraints:
// 
// n == gas.length == cost.length
// 1 <= n <= 105
// 0 <= gas[i], cost[i] <= 104
 
func canCompleteCircuit(gas []int, cost []int) int {
 
    sumGas := 0 // Сюда суммирую элементы слайса gas
    for _, n := range gas {
        sumGas += n
    }
 
    sumCost := 0 // Сюда суммирую элементы слайса cost
    for _, n := range cost {
        sumCost += n
    }
 
    // Пути нет в том случае если сумма топлива меньше суммы топлива необходимого на перемещение
    if sumGas < sumCost {
        return -1
    }
 
    tank := 0 // Количество топлива в баке
    iterationIndex := 0 // Индекс итерации по слайсу
    startIndex := 0 // Индекс элемента с которого возможно начать путь
 
    // Прерываю цикл когда все элементы перебраны
    for len(gas) > iterationIndex { 
        // Количество топлива в баке равно оставшееся топливо полюс топлива наи итерируемой станции
        // минус количество топлива необходимое чтобы добраться до следующей станции.
        tank += gas[iterationIndex] - cost[iterationIndex]
        // Если расчетное количество топлива в баке меньше нуля
        if tank < 0 {
            // Обнулить количество топлива в баке
            tank = 0
            // Начать путь со следующего индекса
            startIndex = iterationIndex + 1
        }
        // Инкрементировать индекс итерации
        iterationIndex++
    }
    // Вернуть индекс начала пусти
    return startIndex
}

Go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
func TestCanCompleteCircuit(t *testing.T) {
    data := []struct {
        gas      []int
        cost     []int
        expected int
    }{
        {
            []int{1, 2, 3, 4, 5},
            []int{3, 4, 5, 1, 2},
            3,
        },
        {
            []int{2, 3, 4},
            []int{3, 4, 3},
            -1,
        },
    }
 
    for i, datum := range data {
        result := canCompleteCircuit(datum.gas, datum.cost)
 
        if result != datum.expected {
            t.Errorf("unexpected result for test index %d expected [%d] got [%d]", i, datum.expected, result)
        }
    }
}
Code
1
2
3
=== RUN   TestCanCompleteCircuit
--- PASS: TestCanCompleteCircuit (0.00s)
PASS
Метки go, problem
Размещено в Без категории
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 0
Комментарии
 
Новые блоги и статьи
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
Модель здравосохранения 18. Чем здоровее работник, тем быстрее выгорает
anaschu 24.05.2026
Имитационная модель корпоративного здравоохранения: что показывает математика Сегодня в модели рабочего коллектива на AnyLogic появились три новые механики — выгорание через накопленную усталость,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru