c - 我的程序在代码的一部分中自行停止。如何修复它?

标签 c cycle-detection

我正在编写一个验证树中循环的程序。小数据还好,但是当数据增加时,它就停止了。请帮助我。

Cromosoma *kruskalModificado(Gen *setGenes, int numGenes, int numVertices, Cromosoma *cromosoma){
int **matrizAux=NULL;
matrizAux=inicializarMatriz(matrizAux,numVertices);
int *posicionesFinales=(int *) calloc(numVertices,sizeof(*posicionesFinales));
int *vecGenes=(int*) calloc(numVertices,sizeof(*vecGenes));
int listo;
int indiceRandom,elegidos=0;
while(elegidos<numVertices-1){//Itero hasta que todos los vertices hayan sido agregados al arbol
    indiceRandom=rand()%numGenes;//Indice aleatorio de mi conjunto de genes
    if(vecGenes[indiceRandom]==1)
        continue;
    vecGenes[indiceRandom]=1;
    Gen genAux=setGenes[indiceRandom];//Obtengo el gen
    //Verifico que vertice aun no ha sido agregado y lo agrego a mi conjunto de componentes.
    listo=1;
    int *visitados=(int *) calloc(numVertices,sizeof(*visitados));
    valido(matrizAux,numVertices,genAux.v1,genAux.v2,&listo,visitados);
    free(visitados);
    printf("Aqui\n");
    if(listo==0)
        continue;
    (*cromosoma).genes[(*cromosoma).numGenes]=genAux;
    (*cromosoma).numGenes++;
    (*cromosoma).fitnessValue+=genAux.peso;
    elegidos++;
    matrizAux[genAux.v1][posicionesFinales[genAux.v1]]=genAux.v2;
    matrizAux[genAux.v2][posicionesFinales[genAux.v2]]=genAux.v1;
    posicionesFinales[genAux.v1]++;
    posicionesFinales[genAux.v2]++;
}
free(posicionesFinales);
free(vecGenes);
for(int i=0 ; i < numVertices; i ++)
    free(matrizAux[i]);
return (Cromosoma *)cromosoma;

}

这是代码的另一部分。

void valido(int **matriz, int numVertices, int genInicial, int genFinal,int *listo, int *visitados){
if(genInicial==genFinal){
    (*listo)=0;
    return ;
}
int j=0;
visitados[genInicial]=1;
while(matriz[genInicial][j]!=-1 && j<numVertices &&(*listo)==1){
    if(visitados[matriz[genInicial][j]]==0){
        valido(matriz,numVertices,matriz[genInicial][j],genFinal,listo,visitados);
    }

    j++;
}
return ;
}

Valido 函数帮助我检测给定边缘中的循环。

最佳答案

在 int vecGenes=(int) calloc(numVertices,sizeof(*vecGenes)); .. 不是 numVertices,而是 numGenes。

关于c - 我的程序在代码的一部分中自行停止。如何修复它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59365493/

相关文章:

algorithm - 循环检测算法 : Is there a condition for Tortoise and Hare to enter into cycle?

java - 邻接链表循环检测 - Java

c - C如何推断 "assignable values"/l-values

C 线性搜索无法使用 strcmp 比较两个字符串,编译正常

c - C 中的 POSIX 线程

c - 以下代码片段的输出是什么?为什么?

javascript - 编写一个函数来检测链表中的循环(Floyd's alg)...逻辑看起来正确,但找不到错误

algorithm - 生成具有 n 个循环的有向图

c - 解释 v < 0 时的情况