Хобрук: Ваш путь к мастерству в программировании

Найдите допустимые узлы в сетке на основе диапазона X

У меня проблема с поиском N позиций в сетке на основе центральной точки и максимального диапазона.

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

Сначала я попробовал решение с использованием A*, где я выбирал каждую координату в диапазоне, проверял, верны ли они, если бы они были, я бы вызывал A* от них до центральной позиции и подсчитывал количество шагов, если они были выше чем мой максимальный диапазон, я бы просто удалил координату из своего списка. Конечно, это действительно медленно для диапазонов выше 3 или сеток с большим количеством координат. Затем я попробовал рекурсивно искать координаты, начиная с центральной, расширяя и рекурсивно проверяя правильность координат. Это решение оказалось наиболее эффективным, за исключением того, что в моем коде каждый вызов функции перепроверял уже проверенные координаты и возвращал повторяющиеся значения. Я думал, что могу просто разделить «проверенный» список между вызовами функций, но это просто сломало мой код, поскольку вызов проверял координату и закрывал ее, даже если у него все еще были дочерние узлы, но технически они не находились в диапазоне их центра ( но были в пределах досягаемости первого центра) это закроет их и даст какие-то странные результаты.

Наконец, мой вопрос: как мне это сделать? Мой подход неверен? Есть ли лучший способ сделать это?

Спасибо.


Ответы:


1

Я реализовал что-то подобное однажды. Предложенное вами простое рекурсивное решение отлично работало для небольших диапазонов ходьбы, но время выполнения вышло из-под контроля для больших значений...

Я улучшил это, реализовав вариант алгоритма Дейкстры, который, как вы сказали, хранит список посещенных узлов. Но вместо того, чтобы запускать поиск полного пути для каждой координаты в пределах досягаемости, как вы делали с A*, выполните первые N итераций алгоритма, если N — ваш диапазон ходьбы (gif в Википедии может помочь вам понять, что я имею в виду). Ваш список посещенных узлов будет представлять собой доступные плитки, которые вы ищете.

http://en.wikipedia.org/wiki/Dijkstra%27s_algorithm

04.11.2011
  • Это сработало! Было немного сложно реализовать это правильно, но, в конце концов, это было лучшим решением. Спасибо :) 25.11.2011
  • Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

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

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..