TGTGInsightтелеграм анализLIVE / telegram public index
← Такты, стеки, два колеса

TGINSIGHT SIMILAR POSTS

Намери подобно съдържание

Изходен канал @clockstackwheels · Post #1084 · 9.04

В общем, была задача на оптимизацию плана работ: есть набор заказов, и в каждом N тасков. Таски могут зависеть друг от друга или нет, имеют длительность и тип. Ещё есть M работников, каждый из которых может выполнять таски только определённых типов, причём, у каждого своя скорость. Если все таски в заказе выполнены, фирма получает сколько-то денег. У заказа есть дедлайн, за просрочку штраф (за каждый день просрочки), который вычитается из цены заказа. И ещё фирма тратит деньги за каждый день своей работы независимо от того, как загружены её сотрудники (то есть просто платит зарплаты по сути). Ещё важен учёт праздников и выходных. Нужно заработать на определённом наборе заказов и работников как можно больше денег. Полный текст задачи и код программы проверки есть в репозитории. Эта задача является изменённым заказом, который мы с напарником решали в реальной жизни: оптимизация работы печатных станков для типографии. Правда, тогда и мы справились так себе, и заказчик в итоге сначала захотел всё вручную сам делать, а потом и вовсе похоронил проект при смене директора. !!! Не читайте дальше, если хотите сначала попробовать решить самостоятельно, потому что я сейчас опишу эффективные подходы и результаты. ________________________________________ Так вот. Мы с другим экспертом Андреем сразу сели и написали разные варианты, чтобы задать шкалу, по которой будем оценивать решения команд. За пару часов я собрал примитивный жадный алгоритм, который сортировал заказы по прибыльности и укладывал в сетку кое-как, это дало нам нижнюю оценку. Мой алгоритм заработал ~75 млн виртуальных рублей, мы решили для оценки поставить нижней границей 40 млн. То есть всё, что ещё ниже, оценивалось в ноль баллов за качество оптимизации. Затем Андрей закрылся дома на три дня и вышел на свет со сложным жадным алгоритмом, который очень хитро сортировал заказы и очень хитро укладывал их в сетку, попутно выбирая разные способы этой укладки в зависимости от конкретного заказа. Это позволило заработать ~275 млн рублей. Мы сделали верхней границей для оценки 280 млн. К сожалению, в итоге только две команды из десяти прошли нижнюю границу, заработав, соответственно, ~91 и ~105 млн. К верхней границе не приблизился никто. И у четырёх команд алгоритм вообще не смог уложить без нарушений задачи в сетку (то есть, например, произвольно менял длительности, накладывал задачи друг на друга, давал одному работнику две задачи в один момент и так далее). Важной ошибкой команд, на мой взгляд, являлся тот факт, что никто не воспользовался возможностью запустить алгоритм на несколько минут и дать ему поработать. По условиям задания, можно было тянуть до 5 минут на одну оптимизацию, но по факту решения команд отрабатывали за единицы и десятки секунд. На самом конкурсе, пока команды работали, я решил попробовать сделать быстрое (по времени написания) но эффективное решение. Сначала попробовал жадную сортировку + доведение до лучшего варианта методом имитации отжига. В качестве нового состояния я просто менял местами заказы целиком. Этот вариант работал пару минут и дал мне около ~200 млн дохода. К слову, команда-лидер использовала такой же подход, просто не докрутила число итераций и температуру. Ну и потом я взял готовую либу по реализации классической генетики с особями и скрещиванием. Особью был массив с приоритетами заказов (которые конечно же нужно было аккуратно уложить чистым алгоритмом). Тип скрещивания: scattered. Всего 15 поколений по 20 особей, и это за минуту-полторы давало ~230-240 млн. Считаю, что для конкурса это самый лучший выбор: пишется одним человеком за день и даёт почти максимум, при этом легко настраивается на нужную длительность работы, легко параллелится. Ну а потом уже дома я посидел и накодил свой вариант сложного жадного с плавающим окном перебора отсортированных заказов и плавающей же укладкой по работникам. Такая штука за две минуты зарабатывает ~281 млн. Но за три дня в условиях стресса я бы такое не сделал, скорее всего. #dev

Hashtags

Резултати

Намерени 15 подобни публикации

Търсене: #remember

当前筛选 #remember清除筛选
Lsposed Modules Updates Tracker

@lsposed_Modules_Updates_Trackers · Post #6229 · 18.03.2026 г., 15:30

#Remember#rafareborn 模块:eu.hxreborn.remembermysort 简介:Remember My Sort 版本:300-3.0.0 更新时间:2026/03/18 18:13:22 更新日志: 💥 BREAKING CHANGES due to df21727 - migrate to libxposed API 101 (commit by @hxreborn): Migrates from libxposed API 100 to 101. API 100 will no longer be supported once 101 is officially released. An LSPosed Manager with API 101 support may not be @lsposed_Modules_Updates_Trackers | @lsposed_Geeks_Bot

Lsposed Modules Updates Tracker

@lsposed_Modules_Updates_Trackers · Post #6153 · 09.03.2026 г., 21:30

#Remember#rafareborn 模块:eu.hxreborn.remembermysort 简介:Remember My Sort 版本:202-2.0.1 更新时间:2026/03/10 04:51:04 更新日志: 🐛 Bug Fixes ef31320 - prevent dimId from being misinterpreted as the sort direction (commit by @hxreborn) Restores sort preferences for users upgrading from v1.x. @lsposed_Modules_Updates_Trackers | @lsposed_Geeks_Bot

Journey to Fluency

@fluencyinenglish · Post #7068 · 23.04.2019 г., 03:06

‍#grammar #remember #infinitive 1⃣ Remember + Infinitive 1⃣ به خاطر داشتن کاری که باید در اینده انجام دهید 2⃣ Remember + Gerund 2⃣ به خاطر داشتن کاری که در گذشته انجام داده‌اید 🆘 Infinitive: to + Verb 🆘 Gerund: Verb + ing @ieltsstrategies @fluencyinenglish

Journey to Fluency

@fluencyinenglish · Post #6746 · 08.01.2019 г., 06:20

#remember #forget #try @fluencyinenglish ❇️Remember + gerund This is when you remember something that has happened in the past. You have a memory of it, like being able to see a movie of it in your head. I remember going to the beach when I was a child. (= I have a memory of going to the beach). He remembers closing the door. (= He has a memory of closing the door). @fluencyinenglish ❇️Remember + to + infinitive This is when you think of something that you need to do. (And usually, you then do the thing). I remembered to buy milk. (= I was walking home and the idea that I needed milk came into my head, so I bought some). She remembered to send a card to her grandmother @fluencyinenglish ❇️ Forget + gerund This is the opposite of remember + gerund. It's when you forget about a memory, something that you've done in the past. Have we really studied this topic before? I forget reading about it. I told my brother that we'd spent Christmas at Granny's house in 1985, but he'd forgotten going there. @fluencyinenglish ❇️Forget + to + infinitive This is the opposite of remember + to + infinitive. It's when you want to do something, but you forget about it. I forgot to call my mother. (= I wanted to call my mother, but when it was a good time to call her, I forgot. I was thinking about something else, and the idea to call my mother didn't come into my head). She keeps forgetting to bring his book back. @fluencyinenglish ❇️Try + gerund This is when you do something as an experiment. The thing you do is not difficult, but you want to see if doing it will have the result that you want. I wanted to stop smoking, so I tried using nicotine patches. (= Using nicotine patches was easy, but I wanted to know if it would help me stop smoking). She tried giving up chocolate, but it didn't help her lose weight. (It was easy for her to give up chocolate. She gave it up to see if it would help her lose weight, but it didn't). @fluencyinenglish ❇️Try + to + infinitive This is when the thing you do itself is difficult. In the present tense or future tense, this means you might not succeed in doing it. In the past tense, it means that you made an effort to do the thing, but you did not succeed. I'll try to carry the suitcase, but it looks too heavy for me. She tried to catch the bus, but she couldn't run fast enough @fluencyinenglish ❇️Regret + gerund This is when you are sorry about something you did in the past and you wish you hadn't done it. I regret going to bed so late. I'm really tired today. She regrets leaving school when she was sixteen. She wishes that she had studied more and then gone to university. @fluencyinenglish ❇️Regret + to + infinitive We use this construction when we are giving someone bad news, in quite a formal way. The verb is almost always something like 'say' or 'tell' or 'inform'. I regret to tell you that the train has been delayed. The company regrets to inform employees that the London office will close next year. @fluencyinenglish

12
ПредишнаСтр. 1 от 2Следваща