c ++ «ошибка функции совпадения», возвращающая двумерный массив

0

Я новичок в c++ и довольно уверен, что ошибка в переменных, которые я передаю в функцию. По сути, у меня есть две функции, определенные в файле double_arrays.cpp - сначала нужно определить эвклидово расстояние между двумя векторами (передано в виде массивов с 10 значениями, эта функция отлично работает). Другой (ближайший) - это найти, какие два вектора (опять же каждый из которых определяется как массив с 10 значениями) ближе всего на расстоянии. Когда я вызываю эту функцию в моем файле "main.cpp", я получаю ошибку "без соответствия функции closeestPair".

Я уверен, что ошибка либо в значениях, которые я передаю в функцию, либо в том, как я пытаюсь ее вернуть (путем печати значений на консоли).

ОТКАЗ ОТ ОТВЕТСТВЕННОСТИ - ЭТО ЕСЛИ ДЛЯ НАЗНАЧЕНИЯ :), поэтому намеки на решение будут более чем приветствуются!

Вот мои файлы:

main.cpp:

#include <iostream>
#include "double_arrays.h"

int main(int argc, const char * argv[])
{

//Define test values to test vectDistance
    double first[10] = {
        0.595500, 0.652927, 0.606763, 0.162761, 0.980752, 0.964772, 0.319322, 0.611325, 0.012422, 0.393489
    };
    double second[10] = {
        0.416132, 0.778858, 0.909609, 0.094812, 0.380586, 0.512309, 0.638184, 0.753504, 0.465674, 0.674607
    };

    //call vectDistance with test values, should equal 1.056238

    std::cout << "Euclidian distance is " << vectDistance(first, second) << std::endl;
    std::cout << "Should equal ~1.056238" << std::endl;

//Define test values for closestPair

    double a[10] = {
        0.183963, 0.933146, 0.476773, 0.086125, 0.566566, 0.728107, 0.837345, 0.885175, 0.600559, 0.142238
    };
    double b[10] = {
        0.086523, 0.025236, 0.252289, 0.089437, 0.382081, 0.420934, 0.038498, 0.626125, 0.468158, 0.247754
    };
    double c[10] = {
        0.969345, 0.127753, 0.736213, 0.264992, 0.518971, 0.216767, 0.390992, 0.242241, 0.516135, 0.990155
    };

//create 2D array to send to closestPair

    double** test = new double*[3];
    test[0] = a;
    test[1] = b;
    test[2] = c;

//output the values of the two vectors which are closest, in Euclidian distance
        std::cout << closestPair(test) << std::endl;

    return 0;
}

double_arrays.cpp:

#include "double_arrays.h"
#include <iostream>
#include <vector>
#include <math.h>

double vectDistance( double first[], double second[]) {
    int i = 0;
    double distance = 0.0;
    for (int j = 0; j < 10; ++j) {
        distance += pow((first[j] - second[i]), 2);
        ++i;
    }
    return distance = pow(distance, 0.5);
}

double** closestPair(double arrays[][10]) {
    double** closest = new double*[2];
    closest[0] = new double[10];
    closest[0] = arrays[0];
    closest[1] = new double[10];
    closest[1] = arrays[1];


    double minDistance = vectDistance(arrays[0], arrays[1]);

    for (int i = 0; i < 9; ++i){
        for (int j = i + 1; j < 10; ++j) {
            if (vectDistance(arrays[i], arrays[j]) < minDistance) {
                minDistance = vectDistance(arrays[i], arrays[j]);
                closest[0] = arrays[i];
                closest[1] = arrays[j];
            }
        }
    }

    return closest;
}

И, наконец, заголовочный файл header.h:

#ifndef double_arrays_double_arrays_h
#define double_arrays_double_arrays_h

double vectDistance( double first[], double second[]);
double** closestPair(double arrays[][10]);

#endif
  • 1
    Если вы собираетесь использовать жесткий размер кода, вы должны использовать const int вместо 10 с, чтобы изменить его при изменении. Также вы уверены, что new double*[3] соответствует double arrays[][10] ?
  • 1
    подсказка: std :: array
Показать ещё 2 комментария
Теги:
pointers
function

2 ответа

1

Ваши файлы заголовков не совпадают, это должно быть:

#ifndef _DOUBLE_ARRAYS_H_
#define _DOUBLE_ARRAYS_H_

Затем в вызове файла double_arrays.cpp:

#include "double_arrays.h"

Чтобы вызвать ваши объявленные функции из файла заголовка в файле.cpp, попробуйте:

double ** Double_Arrays::closestPair(double arrays[][10]) {
/... your code.../
return closest;
}
1

Тип double** несовместим с типом аргумента closestPair.

Допустимые аргументы для closestPair:

const int N = 20;
double arrays[N][10];  // Can use array to call closestPair

или

const int N = 20;
double (*arrays)[10] = new double[N][10];  // Can use array to call closestPair

Ещё вопросы

Сообщество Overcoder
Наверх
Меню