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

[golang] 135. Candy

Запись от alhaos размещена 21.02.2025 в 10:00
Показов 1878 Комментарии 2
Метки go, problem

Дан массив рейтинга детей, по этому рейтингу нужно раздать конфеты.
- Каждый ребенок должен получить хотя бы одну конфету.
- Дети с более высоким рейтингом должны получать больше конфет, чем их соседние дети с более низким рейтингом.

Найти минимальное количество конфет.

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
// [url]https://leetcode.com/studyplan/top-interview-150/[/url]
 
package topInterview
 
// candy
//
// 135. Candy
// There are n children standing in a line. Each child is assigned a rating value given in the integer array ratings.
//
// You are giving candies to these children subjected to the following requirements:
//
// Each child must have at least one candy.
// Children with a higher rating get more candies than their neighbors.
// Return the minimum number of candies you need to have to distribute the candies to the children.
//
// Example 1:
//
// Input: ratings = [1,0,2]
// Output: 5
// Explanation: You can allocate to the first, second and third child with 2, 1, 2 candies respectively.
// Example 2:
//
// Input: ratings = [1,2,2]
// Output: 4
// Explanation: You can allocate to the first, second and third child with 1, 2, 1 candies respectively.
// The third child gets 1 candy because it satisfies the above two conditions.
//
// Constraints:
//
// n == ratings.length
// 1 <= n <= 2 * 104
// 0 <= ratings[i] <= 2 * 104
func candy(ratings []int) int {
 
    // Length содержит длину массива ratings
    length := len(ratings)
 
    // Создаем слайс для подсчета и сравнения полученных конфет
    candies := make([]int, length)
 
    // Раздаем по конфете
    // Условие "Each child must have at least one candy."
    for i, _ := range candies {
        candies[i] = 1
    }
 
    // Обходим слайс слева направо до предпоследнего элемента
    for i := range length - 1 {
        // Если рейтинг текущего ребенка меньше рейтинга ребенка справа
        if ratings[i] < ratings[i+1] {
            // Ребенок справа получает на одну конфету больше чем есть у текущего ребенка
            candies[i+1] = candies[i] + 1
        }
    }
 
    // Обходим слайс справа налево до второго элемента
    for i := length - 1; i > 0; i-- {
        // Если у текущего ребенка рейтинг ниже чему у ребенка слева
        // и у конфет у текущего ребенка больше или столько же как у ребенка слева
        if ratings[i] < ratings[i-1] && candies[i] >= candies[i-1] {
            // У ребенка слева становится конфет больше на одну чем у текущего
            candies[i-1] = candies[i] + 1
        }
    }
 
    // Возвращаем сумму конфет
    sum := 0
    for _, n := range candies {
        sum += n
    }
    return sum
}
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
func TestCandy(t *testing.T) {
    data := []struct {
        ratings  []int
        expected int
    }{
        {
            []int{1, 0, 2},
            5,
        },
        {
            []int{1, 2, 2},
            4,
        },
        {
            []int{1, 3, 2, 2, 1},
            7,
        },
        {
            []int{1, 2, 87, 87, 87, 2, 1},
            13,
        }, {
            []int{1, 3, 4, 5, 2},
            11,
        },
    }
 
    for i, datum := range data {
        result := candy(datum.ratings)
 
        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   TestCandy
--- PASS: TestCandy (0.00s)
PASS
Метки go, problem
Размещено в Без категории
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 2
Комментарии
  1. Старый комментарий
    Рейтинг дан, а сами конфеты не даны
    Запись от testuser2 размещена 22.02.2025 в 04:02 testuser2 на форуме
  2. Старый комментарий
    Аватар для alhaos
    Да наоборот же, они даны без ограничения мы сможем их просто плюсовать, вот бы в жизни так...
    Запись от alhaos размещена 22.02.2025 в 05:45 alhaos вне форума
 
Новые блоги и статьи
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 появились три новые механики — выгорание через накопленную усталость,. . .
Модель здравосохранения 17. Планы на выгорание
anaschu 23.05.2026
Вот конкретная схема реализации: В классе Работник добавить: накопленнаяУсталость — растёт каждый час работы, снижается в перерывы и болезни коэффициентПрезентеизма — снижает продуктивность. . .
Изменение цветов в палитре gif файла aka фавикона
russiannick 23.05.2026
Изменение цветов в палитре gif файла, юзаемого как фавиконка в составе html-файла, помещенная в base64, средствами нативного Java Script, навеянное сном в майский день. Для работы необходим браузер,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru