Привет. Заметил в игре Warpips интересную механику когда артиллерия бьёт

в скопление врагов. Хочу повторить это. Может кто подкинуть идею как это реализовать? (как выбрать максимально большую группу точек на плоскости, описываемую окружностью заданного диаметра, найти центр этой окружности)

9 ответов

18 просмотров

а я бы сделал так, кинул бы по радиусу, и расширял бы пока например в нем не наберется 200 юнитов условно, при их наборе, делали бы свой круг на 4 части, и в которой из частей больше юнитов, его бы брал в фокус и вот тебе пожалуйста

Михаил
а я бы сделал так, кинул бы по радиусу, и расширял...

а если по центру получится? ну т.е. круг должен быть на пересечении этих 4х частей?

Какая асимптотика решения задачи желаемая? Известно, что решение твоей задачи это описанная вокруг некоторого треугольника из трёх точек окружность. Соответственно тебе стоит выбрать такую, которая имеет меньший радиус чем ты задал и включает максимальное число точек. За n^4 это точно решается.

Да, не нужно. Это промежуточный шаг алгоритма. Так вы найдете центр, далее подставите нужный радиус.

Alexey-Gordiychuk Автор вопроса
Григорий Минаков
Да, не нужно. Это промежуточный шаг алгоритма. Так...

А, я понял. Но тогда нужно знать в каждой ноде все остальные что ближе радиуса, а не использовать только ближайшие две?

Alexey Gordiychuk
А, я понял. Но тогда нужно знать в каждой ноде все...

Да нужно перебирать все точки. Еще раз: вам нужно перебрать центры всех описанных оркужностей - их n^3, для каждой найти число точек попадающих в нее, и за n и выбрать лучшую. Поймите, что для заданного радиуса решение не единственно в общем случае. Эту задачу можно точно решать эффективнее, для этого стоит ознакомиться с вот этой задачей - https://ru.wikipedia.org/wiki/%D0%97%D0%B0%D0%B4%D0%B0%D1%87%D0%B0_%D0%BE_%D0%BD%D0%B0%D0%B8%D0%BC%D0%B5%D0%BD%D1%8C%D1%88%D0%B5%D0%B9_%D0%BE%D0%BA%D1%80%D1%83%D0%B6%D0%BD%D0%BE%D1%81%D1%82%D0%B8. Это другая задача, но предложенные решения этой задачи можно обобщить и на вашу.

Мне кажется, что решение с нодами неточное, насколько я его понял. Про два скопления точек - это кажется уже другая задача).

Alexey-Gordiychuk Автор вопроса
Григорий Минаков
Мне кажется, что решение с нодами неточное, наскол...

Ну если нодами не правильно, а ваш вариант сработает то мне бы понять как его сделать

Похожие вопросы

Обсуждают сегодня

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта