|
0 / 0 / 0
Регистрация: 11.01.2025
Сообщений: 4
|
|
За один ход увеличить или уменьшить любой элемент массива на 1, всего таких операций можно сделать не больше K11.01.2025, 17:09. Показов 6223. Ответов 77
Метки нет (Все метки)
Дан список A из N чисел, а также число K. Можно за один ход увеличить или уменьшить любой элемент массива на 1, всего таких операций можно сделать не больше K раз.
Какая макс. длина может быть у какого-то подотрезка, в которым все элементы одинаковые? В первой строке два числа - N и K. Во второй строке N чисел, i-тый элемент равен A[i]. Ограничения: 1 ≤ N ≤ 100 000 0 ≤ K ≤ 1 000 000 000 0 ≤ A[i] ≤ 100 000 000 Ввод: 11 7 3 5 8 9 2 7 6 5 3 9 7 Вывод: 4 Объяснение: Можно выбрать отрезок 2-7-6-5. Выполним операцию 4 раза на первом элементе, тогда получаем 6-7-6-5. Выполним операцию 1 раз на втором элементе, итого 5 операции, получаем 6-6-6-5. Выполним операцию на последнем элементе, итого 6 операции, получаем 6-6-6-6. Все элементы одинаковы, значит размер отрезка (4) подходит. Можно показать, что больше такого отрезка, с длиной больше 4, нет.
0
|
|
| 11.01.2025, 17:09 | |
|
Ответы с готовыми решениями:
77
За один ход любое одно из чисел уменьшить на любой степень двойки Описать ход выполнения таких операций Как можно увеличить или уменьшить изображения в Image с помощью TrackBar-а? |
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
|||
| 17.01.2025, 18:55 | |||
|
0
|
|||
| 17.01.2025, 21:06 | ||
|
А где ТС? Он так рвался оптимизировать, ну вот оно, оптимальное, нюхайте
0
|
||
|
30 / 24 / 7
Регистрация: 22.02.2019
Сообщений: 105
|
||||||||||||
| 18.01.2025, 15:18 | ||||||||||||
|
При попытке запустить решение от Shamil1 на приаттаченных данных оно упало с переполнением стека. Удалось запустить в отдельном потоке со стеком 16MB:
1
|
||||||||||||
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
|||
| 18.01.2025, 17:42 | |||
|
Добавлено через 25 минут
0
|
|||
|
30 / 24 / 7
Регистрация: 22.02.2019
Сообщений: 105
|
|
| 18.01.2025, 17:59 | |
|
А вы не обратили внимание, что результаты отличаются?
0
|
|
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
|
| 18.01.2025, 21:12 | |
|
Обратил.
0
|
|
| 19.01.2025, 03:50 | |||||||
|
Вот мой вариант на плюсах
Кликните здесь для просмотра всего текста
Интересно что избавиться от трудного пересчета медианы мне не удалось. Да, здесь он короче и быстрее (за это заплачено контейнером), но по-прежнему трудноват для понимания и реализации, нет желанной простоты. Не исключено что и насвистел
0
|
|||||||
|
30 / 24 / 7
Регистрация: 22.02.2019
Сообщений: 105
|
||
| 19.01.2025, 09:38 | ||
|
Имея заданный массив, начало и конец отрезка, количество ходов можно подсчитать просто отсортировав массив на этом отрезке. У меня на отрезке [11615, 91759] получилось 1000392967.
0
|
||
| 19.01.2025, 17:52 | |||||||
|
Подправил, добавил тест результата
Кликните здесь для просмотра всего текста
![]() Дело не столько в скорости сколько в "перспективах" данного кода. Случись что - и разобраться другому программисту будет трудно (если вообще возможно). Вероятно придется все снести и писать с нуля.
0
|
|||||||
|
691 / 575 / 75
Регистрация: 20.09.2014
Сообщений: 3,750
|
|||
| 19.01.2025, 18:39 | |||
|
Например, нечётное число элементов [3, 5, 6, 7, 9] median([3, 5, 6, 7, 9]) = 6 Отклонение от медианы: (6-3) + (6-5) + Можно посчитать "в лоб", но так неинтересно. Обратим внимание, что саму медиану можно не учитывать, он всегда самоликвидируется. Чисел до медианы и после медианы всегда одинаковое. Это значит, что числа "6" можно поголовно сократить. ( То есть надо просуммировать числа после медианы и вычесть из них все числа до медианы. (7 + 9) - (3 + 5) Например, чётное число элементов [3, 5, 6, 7, 8, 9] median([3, 5, 6, 7, 9]) = [6, 7] -> 6 (я беру меньшую из медиан) Отклонение от медианы: (6-3) + (6-5) + В конце добавилась разница медиан.
0
|
|||
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
|||||||||||
| 19.01.2025, 23:04 | |||||||||||
|
Я переписал на использование дерева для хранения окна.
Использовал декартово дерево, как самое простое. Алгоритмы добавления/удаления из дерева выбрал самые простые, а не самые оптимальные. Результат (на стареньком ноутбуке):
0
|
|||||||||||
| 20.01.2025, 01:46 | |
|
Не по теме: единственное, что я понял: данная задача очень просто и лаконично звучит, но вот решается совсем непросто, ну, судя по кол-ву обсуждений...ну и ладно, пойду чаек заварю...
0
|
|
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
||||||
| 20.01.2025, 11:52 | ||||||
|
Я пробовал использовать SortedSet, который является деревом и обещает O(log n) для всех операций. Но программа неожиданно работает примерно как O(n2). 3ms - 270ms - 37sec для n = 1000 - 10000 - 100000. Ответ выдаёт правильный.
Код практически тот же самый:
Выяснилось, что в SortedSet нет метода для получения элемента по индексу. Используется метод из IEnumerable, который O(n).
0
|
||||||
| 20.01.2025, 12:48 | ||
0
|
||
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
|
| 20.01.2025, 14:26 | |
|
0
|
|
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
||||
| 20.01.2025, 16:21 | ||||
|
0
|
||||
|
691 / 575 / 75
Регистрация: 20.09.2014
Сообщений: 3,750
|
|
| 20.01.2025, 19:25 | |
|
Две медианы ищутся за время O(1), нет необходимости их помнить, при чём на 50% зря.)))
0
|
|
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
|
| 20.01.2025, 20:08 | |
|
0
|
|
|
691 / 575 / 75
Регистрация: 20.09.2014
Сообщений: 3,750
|
|
| 20.01.2025, 20:45 | |
|
[3, 5, 6, 7, 8, 9]
Вот же они по середине. Индекс первой медианы 6/2-1 = 2, индекс второй медианы 6/2 = 3 (индексы начинаются с нуля).
0
|
|
| 20.01.2025, 20:45 | |
|
Помогаю со студенческими работами здесь
60
Элементы массива уменьшить на 20, умножить на последний элемент и увеличить на число В Элементы массива: увеличить в 2 раза, уменьшить на число А, разделить на первый элемент
Найти максимальный по значению элемент массива и увеличить его в два раза, остальные элементы уменьшить на значение минимума последней строки массива Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2.
Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом.
В. . .
|
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2.
Задача: отобразить спецтехнику, которая на данный момент находится в ремонте.
Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
|
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
|
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
|
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|