Я новичок, пожалуйста, помогите мне с этим вопросом по кодированию [закрыто]C++

Программы на C++. Форум разработчиков
Ответить
Anonymous
 Я новичок, пожалуйста, помогите мне с этим вопросом по кодированию [закрыто]

Сообщение Anonymous »

Путешествие рыцарей, в котором нам даны начальная, конечная точки и размер доски (n*n). Найдите минимальные шаги, чтобы добраться до конца из начальной точки. Если пути нет, верните -1.
/>изображение
Я пытался решить эту задачу с помощью dfs, но явно не смог.
это определение класса ячеек.

Код: Выделить всё

#include 
#include 
#include 
using namespace std;

class Cell {
public:
int x, y;
Cell(int x, int y) {
this->x = x;
this->y = y;
}
};

int count(vector& board, int a, int b, int x, int y, int n) {
if (a >= n || b >= n || b < 0 || a < 0 || board[a][b] == 1) return 500;
if (a == x && b == y) return 0;

board[a][b] = 1;

int one = count(board, a + 2, b + 1, x, y, n) + 1;
int two = count(board, a + 2, b - 1, x, y, n) + 1;
int three = count(board, a - 2, b + 1, x, y, n) + 1;
int four = count(board, a - 2, b - 1, x, y, n) + 1;
int five = count(board, a + 1, b + 2, x, y, n) + 1;
int six = count(board, a + 1, b - 2, x, y, n) + 1;
int seven = count(board, a - 1, b + 2, x, y, n) + 1;
int eight = count(board, a - 1, b - 2, x, y, n) + 1;

board[a][b] = 0;

int minMoves = min({one, two, three, four, five, six, seven, eight});

return minMoves;
}

int minMovesRequired(int n, Cell start, Cell end) {
vector board(n, vector(n, 0));
int a = start.x;
int b = start.y;
int c = end.x;
int d = end.y;
int ans = count(board, a, b, c, d, n);

return (ans >= 500) ? -1 : ans;
}

int main() {
int n = 6;
Cell start(6, 1);
Cell end(1, 3);

int result = minMovesRequired(n, start, end);
cout 

Подробнее здесь: [url]https://stackoverflow.com/questions/78720632/i-am-a-beginner-plz-help-me-with-this-coding-ques[/url]
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C++»