170 похожих чатов

А поделитесь знанием про индексирование 2-мерных плоскостей. Дано: Прямоугольная область ([x1,

y1]; [x2, y2])
На данной области располагаются точки [xN, yN], N = 1..10000 (то есть очень много), координаты не целые (то есть стоят все не по сетке), новые точки не появляются в процессе жизни приложения, точки распределены сильно не равномерно. Область можно "проиндексировать" ....
В определенный момент появляется информация о окружности [[Xp, Yp], Rp] где [Xp, Yp] принадлежит плоскости
Нужно максимально быстро найти все точки [xN, yN], которые попадают внутрь этой окружности.

В какую сторону копать?
Есть какой-то аглоритм индексации 2-мерных пространств, котоый дерево поиска построит?
Или использовать 2 дерева для каждой координаты?
(не касаемо питона)

7 ответов

10 просмотров

использовать формулу окружности)

так а у них не одинаковая дельта?

Alexey D.-Filimonov Автор вопроса
Валерій Каспрук
для каждой ячейки массива?

У меня не массив, а плоскость, там координата может быть не целая

Alexey D. Filimonov
У меня не массив, а плоскость, там координата може...

ну можешь брать брать квадрат, в котором находится окружность, и проверять уже все точки квадрата

Есть смысл копать в сторону алгоритмов геоинфсистем (ГИС), там чет какие-то деревья квадрантов за первую минуту гуглинга вылезли

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

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

Такс, блин, таки кто-то знает, каким образом работают макросы stdin/stdout/stderr? Я влез в stdio.h, там определения нет, отладил через асмокод - вызывается функция со странны...
The Bird of Hermes
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Всем привет, на линуксе лучше на fasm или nasm учиться писать для начала ?
meszjol
14
Если у меня есть такой класс: Object = {} function Object:new(a_name, a_transform, a_color, a_mesh, a_material, a_shader, a_textures) local private = {} private.n...
Cuarno Vile
4
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
было так ;void set_http_ver(RESPD* ptr, char* version, uint32_t length) // example: 'RTSP/1.1 ' set_http_ver: mov eax, [esp + 4] mov ecx, [esp + 8] ...
Mixail Frolov
5
@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
зачем же переименовывать ? чтобы кол-во участников возросло или вдруг IBM от этого снова на свифте начнет кодить ? Я не понимаю что страшного в том что свифт гавно, если это т...
Oleh Nerzh
10
здравствуйте. совершаю вот такую вещь: strcpy(line, (char)current_number); где current number — неподписанный шорт, line — массив чаров. ругань следующая: main.c:29:30: error...
Roberto's Ширгозиев
13
Code Explorer / обновление содержимого окна, задержка - задержка, по моему, слишком большая, примерно 1 сек, хотелось-бы установить - макс. быстро - в настройках ide не нашел...
livontiy
1
Карта сайта