Искусственный интеллект — Проблемы с прохождением 2D массива в C ++ 8 Puzzle

По какой-то причине я не могу получить distance функция для работы. Может ли кто-нибудь объяснить мне, что я делаю не так?

Основная функция:

#include <iostream>
#include <cmath>
using namespace std;

int distance(int**, int);

int main()
{
int m;
int goal [3][3] = { {1,2,3},{4,5,6},{7,8,0}};
const int N = 3;
int intial[N][N];
cout << "Enter in values: \n";
for(int i=0; i<3; i++)    //This loops on the rows.
{
for(int j=0; j<3; j++) //This loops on the columns
{
cin >> intial[i][j];
}
}cout << goal[0][0] << "\n" ;
m = distance(intial,N);
system("PAUSE");
return 0;
}

Манхэттен Расстояние расчет!

int distance(int** array,int N)
{

int MSum = 0;
for (int x = 0; x < N; x++){ //Transversing rows(i)
for (int y = 0; y < N; y++) { //traversing colums (j)
int value = array[x][y]; // sets int to the value of space on board
if (value != 0) { // Don't compute MD for element 0
int targetX = (value - 1) / N; // expected x-coordinate (row)
int targetY = (value - 1) % N; // expected y-coordinate (col)
int dx = x - targetX; // x-distance to expected coordinate
int dy = y - targetY; // y-distance to expected coordinate
MSum += abs(dx) +abs(dy);
}
}

}
int m = MSum;
return m;

}

-1

Решение

Это выглядит в основном правильно, насколько логика идет. Массив, который вы передаете, должен быть совместим с объявлением и реализацией функции. Вот пример объявления:

int distance(int array[3][3],int N);
1

Другие решения

Других решений пока нет …

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector