我必须从课堂上做一个程序,我得到了这个错误:
下标值既不是数组也不是指针也不是向量。
错误在
if((matriz[i][j]>maximo)&&(esta(vector[nvertices-1],i,j,nvertices)==0)){
和
siguiente=vector[i];
我不太清楚错误背后的原因是什么。
CODE:
#include<stdlib.h>
#include<stdio.h>
void camino(int* vector,int matriz,int nvertices);
int esta(int vector,int inicio,int fin,int nvertices);
int main(){
int nvertices; //numero de vertices
int nconexiones; //numero de conexiones disponibles
int i,j; //indices para recorrer la matriz
int conex = 0; //rectificador de conexiones
printf("Introduce el numero de vertices: ");
scanf("%d",&nvertices);
printf("Introduce el numero de conexiones disponibles: ");
scanf("%d",&nconexiones);
int matad[nvertices][nvertices]; //matriz de adyacencia
for(i=1;i<=nvertices;i++){ //Rellenar la matriz con ceros, por defecto no hay ninguna conexion
for(j=1;j<=nvertices;j++){
matad[i][j]=0;
}
}
printf("Introduce las capacidades.Si no existe introduce 0:\n");
for(i=1;i<=nvertices;i++){ //Introducimos las capacidades
for(j=1+i;j<=nvertices;j++){
if(conex<nconexiones){
printf("Ciudad %d - Ciudad %d: ",i,j);
scanf("%d",&matad[i][j]);
matad[j][i]=matad[i][j];
conex++;
}
}
}
int caminos[nvertices-1]; //Variable que almacena el camino (como una lista de vertices)
camino(&caminos[nvertices-1],matad[nvertices][nvertices],nvertices);//Llamada a la funcion camino
return 1;
}
void camino(int* vector,int matriz,int nvertices){
int i,j; //Indices para recorrer la matriz de adyacencia
for(i=1;i<=nvertices;i++){ //-- Explicacion --
int maximo = 0; //Vamos a empezar por el vertice 1, bucamos el camino de mayor
for(j=1;j<=nvertices;j++){ //capacidad, una vez lo tenemos comprobamos si esa union 1->X esta
if((matriz[i][j]>maximo)&&(esta(vector[nvertices-1],i,j,nvertices)==0)){ //o no esta en nuestra lista mediante la funcion esta(...), si esta
maximo=j; //lo añadimos y ahora partimos desde el vertice X -> Y, en caso
} //contrario hemos acabado.
} //------------------
} //La variable maximo es utilizada para ver que vertice tiene la mayor
} //capacidad
int esta(int vector,int inicio,int fin,int nvertices){
int anterior=0;
int siguiente=0;
int encontrado=0;
int i;
for(i=1;i<=nvertices-1;i++){
anterior=siguiente;
siguiente=vector[i];
if((inicio==anterior)&&(fin==siguiente)){
encontrado=1;
}
}
return encontrado;
}
答案 0 :(得分:3)
在camino()
函数中,matriz
为int
。
在esta()
函数中,vector
也是int
。
您只能对数组类型变量使用数组索引操作符。