Есть тренировочная сетка, состоящая из квадратов. Некоторые квадраты содержат цветные жетоны. Есть три типа жетонов - красные, зеленые и синие. Каждый квадрат содержит не более одного жетона. В начале тестирования робот стоит на одной клетке сетки, свободной от жетонов.
За один шаг робот может перейти из своего текущего квадрата в любой из соседних квадратов в северном, южном, западном или восточном направлениях, при условии, что эти квадраты действительно существуют. Робот не может выходить за пределы сетки.
Задача робота - передвигаться по сетке, собирать жетоны и возвращаться на стартовую клетку. Любой конкретный жетон можно собрать, только когда робот стоит на квадрате, где находится жетон. Робот должен собрать как минимум по одному жетону каждого цвета.
Задача:
Найдите минимальное количество шагов, которое должен выполнить робот, чтобы собрать хотя бы один жетон каждого цвета и вернуться в исходное положение.
Входные данные:
M N разделенные пробелом кол-во рядов и колонок и сетки
"." (точка) представляет собой пустой квадрат,
«X» (заглавная X) обозначает начальную позицию робота,
"R" (заглавная R) представляет квадрат с красным маркером,
«G» (заглавная G) представляет квадрат с зеленым жетоном,
«B» (заглавная 😎 представляет квадрат с синим жетоном.
Пример:
a)
Input
3 3
G.B
.X.
R..
Output
8
b)
Input
6 5
.GGRG
.....
.X...
.....
B...R
B.RRR
Output
14
c)
11 15
X......R.......
...............
...............
...............
.......G......B
...............
...............
...............
...............
...............
R.G.B..........
Output
28

Успешно разработанной программа считается:
1) Написана на перечисленных в названии проекта ЯП
2) Должна пройти 10 тестов:
2.1) На время выполнения программы;
2.2) Правильность выполнения программы
2.3)Тестами являются обычный текстовые файлы.
3) Плагиата не должно быть
* считывание идет с помощи стандартного потока ввода
Отзыв заказчика о сотрудничестве с Anton Trotsenko
Java/Python/C++ Графы, brute forceУже сотрудничали вместе, все отлично работает, быстро и эффективно.
Прошлый отзыв также актуален.
Отзыв фрилансера о сотрудничестве с Ihor Petrenko
Java/Python/C++ Графы, brute forceСотрудничаем уже второй раз. Все отлично! Рекомендую к сотрудничеству!
-
68 1 0 Здравствуйте!
Интересная задача, готов выполнить в соответствии со всеми требованиями.
-
Есть ли какие-то ограничения на M и N? Какие ограничения по времени?
-
Актуальные фриланс-проекты в категории C и C++
Реверс-инжиниринг консольных утилит для опроса контроллеров SSD (Flash ID)1. Цель работы Выделение программного интерфейса (API) взаимодействия с контроллерами SSD/NVMe из предоставленного набора консольных утилит (Phison, Silicon Motion, Realtek, Maxiotek, Marvell, JMicron и др.). Результатом должно стать рабочий код на языке C/C++ или точная… C и C++, Десктопные приложения ∙ 8 дней 5 часов назад ∙ 6 ставок |
Разработка карты семян Minecraft Java / просмотрщика семян для сайтаРазработка карты семян Minecraft Java / Seed Viewer для сайтаОписание проекта Необходимо разработать браузерный инструмент Minecraft Java Seed Map / Seed Viewer, который будет работать на нашем сайте и позволит пользователю ввести семя Minecraft Java Edition и просмотреть… C и C++, HTML и CSS верстка ∙ 8 дней 12 часов назад ∙ 16 ставок |
Сравнительный анализ эффективности кастомного ПО (v2.2-field) и эталонного ПО (Meshtastic v2.x)
1000 UAH
Сравнительный анализ эффективности кастомного ПО (v2.2-field) и эталонного ПО (Meshtastic v2.x) на идентичной аппаратной платформе (ESP32 + SX1268, 2W) по критериям дальности, пропускной способности, стабильности линка и энергопотребления. Провести тесты с замерами с учетом… C и C++, C# ∙ 12 дней 19 часов назад ∙ 3 ставки |