|
0 / 0 / 0
Регистрация: 07.07.2022
Сообщений: 3
|
||||||
Задача "Борьба с рутиной"07.07.2022, 16:16. Показов 1000. Ответов 4
Метки нет (Все метки)
Здравствуйте, прошу помощи с решением данной задачи:
Борьба с рутиной (Время: 2 сек. Память: 16 Мб Сложность: 52%) Важным элементом повышения эффективности работы сотрудников является борьба с рутиной. Построим математическую модель разнообразия типов заданий, выполняемых сотрудником в компании. Рассмотрим работу сотрудника в течение n последовательных рабочих дней. Будем считать, что каждый день сотрудник выполняет ровно один тип заданий, обозначим тип заданий, выполняемый сотрудником в i-й день, целым числом ai. Для оценки рутинности работы сотрудника будем использовать следующую характеристику. Зафиксируем целое число d и рассмотрим все отрезки из d подряд идущих рабочих дней. Для каждого такого отрезка найдём количество различных типов заданий, которые работник выполнял на протяжении этих дней, и просуммируем эти значения. Полученную величину обозначим как Sd и будем называть её d-разнообразием. Чем d-разнообразие выше, тем больше различных типов заданий выполнял сотрудник. Профилем вариативности сотрудника будем называть массив значений [S1, S2, ... , Sn]. Требуется написать программу, которая по заданной последовательности a1, a2, ... , an типов выполняемых сотрудником заданий вычисляет его профиль вариативности. Входные данные В первой строке входного файла INPUT.TXT находится единственное целое число n — количество последовательных рабочих дней, которые необходимо проанализировать (1 ≤ n ≤ 2×105). Во второй строке находится n целых чисел a1, a2, ... , an — типы заданий, которое выполнял сотрудник (1 ≤ ai ≤ 109). Выходные данные В выходной файл OUTPUT.TXT выведите n целых чисел: S1, S2, ... , Sn. Примеры № INPUT.TXT OUTPUT.TXT 1 5 1 3 2 1 2 5 8 8 6 3 2 3 10 10 10 3 2 1 ################## Сам я писал код на питоне, кому интересно, вот он:
Объясните, пожалуйста, где тут можно сократить объём используемой памяти или как переписать код так, чтобы память не нагружалась так сильно.
0
|
||||||
| 07.07.2022, 16:16 | |
|
Ответы с готовыми решениями:
4
Автоматизация рутиной работы Алгоритм для автоматизации рутиной работы в Adobe нужен ваш совет в создании алгоритма для автоматизации рутиной работы в Adobe |
|
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
|
|
| 07.07.2022, 19:18 | |
|
0
|
|
|
0 / 0 / 0
Регистрация: 07.07.2022
Сообщений: 3
|
|
| 08.07.2022, 01:04 [ТС] | |
|
№1
INPUT.TXT 5 1 3 2 1 2 OUTPUT.TXT 5 8 8 6 3 ___________ №2 INPUT.TXT 3 10 10 10 OUTPUT.TXT 3 2 1
0
|
|
|
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
|
||||||||||||
| 08.07.2022, 10:21 | ||||||||||||
В реализации, чтобы уменьшить память, можно избавиться от сортировки, в алгоритме она опциональна, можно без нее. Странно, что у вас выдало MLE, а не RTE, хотя явно вы не укладываетесь по времени из-за вот этого:
1
|
||||||||||||
|
0 / 0 / 0
Регистрация: 07.07.2022
Сообщений: 3
|
||||||
| 09.07.2022, 18:41 [ТС] | ||||||
|
В s я храню длины отрезков между 2 ближайшими вхождениями одного числа ci в последовательность a, а также длины отрезков от начала и конца последовательности до первого и последнего вхождения числа соответственно. Я решил не добавлять отрезки, которые в последующем не будут использоваться, поэтому, если длина отрезка меньше 3, то я его не включаю в s.
В q хранятся всевозможные числа ci, входящие в последовательность a, в q1 - индекс последнего вхождения ci в a. Спасибо за подсказку, насчёт исключения чисел с конца, а не с начала. Логика решения была такой, что мы для каждого различного ci записываем в s все значения отрезков между его ближайшими 2 вхождениями в последовательность a. Затем по данным из s высчитываем для каждого ci, сколько существует различных отрезков по d подряд идущих дней, которые не включают в себя ci. Сумма результатов будет ответом для данного d, но так как количество отрезков из d подряд идущих дней между 2 вхождениями для любого ci не может быть отрицательной, а 0 мы не учитываем, т.к. он суммы не меняет, приходится удалять все ненужные отрезки из s. Также я заметил, что для d = 1 ответ будет равен n, а для d = n ответ будет длиной q, то есть количеством различных ci в последовательности a. Добавлено через 7 минут Также я забыл упомянуть, что была и 2 попытка, там я реализовал двоичный поиск для нахождения в отсортированном s отрезка, с которого стоит начать подсчёт суммы для следующего d, но там уже была кривая реализация скорее-всего, поэтому дальше 8 теста такой вариант не прошёл из-за неверных ответов. Вот код, но он крайне кривой, потому что такого вида двоичный поиск я реализовывал впервые.
0
|
||||||
| 09.07.2022, 18:41 | |
|
Помогаю со студенческими работами здесь
5
Борьба Борьба с IE Борьба с вирусом борьба с рекламой Борьба с плагиатом Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение:
DISM / Online / Add-Capability / CapabilityName:WMIC~~~~
Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
|
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: при создании документов установить период списания автоматически. . .
|
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2.
Задача: вывести данные из ТЧ нетипового документа. . .
|
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению.
На форме документа создается. . .
|
|
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
|
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
|
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
|
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию.
2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
|