将2-D数组传递给函数会产生奇怪的错误

时间:2015-02-19 21:03:07

标签: c++ arrays function pointers

您好我正在尝试创建一个函数,但它会出错

  [Error] cannot convert 'float (*)[(((sizetype)(((ssizetype)n) + -1)) + 1)]' to 'float (*)[30]' for argument '1' to 'float vecino_mas_cercano(float (*)[30])'

我的代码是:

#include <iostream>
#include<stdio.h>
#include <fstream>
#include<stdlib.h>
using namespace std;

int n1=30;

float nearest_neighbor(float distances[30][30])
{  float min=distances[0][1];
   int candidates[n1];
   int city=0;

   for (int i=0;i<n1;i++)
   {  candidates[i]=i;
   }

   for (int i=0;i<n1;i++)
   {  for (int &j:candidates)
      {  if (j!=0)
            if (distances[city][j]<min);
            {  min=distances[i][j];
               candidates[i]=0;
               city=j;
            }
      }
   }
   return min;
}

int main()
{
   //Declaración de variables

   int n=30; //número de nodos o cityes


   FILE *d;
   float distance[n][n];
   d =fopen("Oli30.csv","r");//r abrir el archivo que contiene las distances para leerlo

   for(int i=0 ;i<n; i++) //en la matriz distance se guardan los valores de las distances
   {  for(int j=0; j<n; j++)
      {  fscanf(d,"%f",&distance[i][j]);}
   }

   float tau_initial;

   tau_initial=nearest_neighbor(distance);  
   cout << "The result is " << tau_initial;
   return 0;

}

我想问题是因为距离被设置为指针,我不知道如何在函数nearest_neighbor中传递这个参数。

有人可以解释一下如何使这个有用吗?

谢谢

3 个答案:

答案 0 :(得分:6)

int n = 30;必须更改为int const n = 30;

如你所知,float distance[n][n]是非法的。标准C ++中的数组必须具有维度的常量。

错误消息表明您的编译器正在为具有非常量维度的数组实现某种扩展(可能类似于C语言VLA),然后它不知道如何将其与期望数组的函数相匹配恒定尺寸。

答案 1 :(得分:3)

我相信你有一个无意的错误:

     if (distances[city][j]<min); // The if block ends here.
     {  min=distances[i][j];
        candidates[i]=0;
        city=j;
     }

你可能意味着:

     if (distances[city][j]<min)
     {
        min=distances[i][j];
        candidates[i]=0;
        city=j;
     }

答案 2 :(得分:0)

可以通过将nearest_neighbordistancemain的参数类型更改为float**来解决此问题。但是,distance的初始化必须以不同方式完成,实际维度应作为参数传递给nearest_neighbor