C-阵列的最大尺寸 - 分割故障



我的代码有一些问题:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void union1(int belongs[],int c1,int c2, int n);
int main()
{
int i=0;
    int j=0;
    int N, num_AERO, num_E;
    if (scanf("%d", &N) != 1) { exit(1); }
    if (scanf("%d", &num_AERO) != 1) { exit(1); }
    int custoAERO[num_AERO];
    for (i = 0; i < num_AERO; i++) 
    {
        int id_aero, cst_aero;
        if (scanf("%d %d", &id_aero, &cst_aero) != 2) { exit(1); }
        custoAERO[i] = cst_aero;
    }
    if (scanf("%d", &num_E) != 1) { exit(1); }
    int *matriz_estradas[N];
    for (i = 0; i < N; i++) 
    {
        matriz_estradas[i] = malloc(sizeof(*matriz_estradas[i]));
    }
    int cid_a, cid_b, cust;
    for(i=0; i< num_E; i++)
    {
        if (scanf("%d %d %d", &cid_a, &cid_b, &cust) != 3) { exit(1); }
        matriz_estradas[cid_a -1][cid_b -1] = cust;
        matriz_estradas[cid_b -1][cid_a -1] = cust;
    }
    for(i=0; i<N; i++)
    {
        int cidade_sozinha = 0;
        for(j=0; j<N; j++)
        {
            if(matriz_estradas[i][j]>0 || matriz_estradas[j][i]>0)
                cidade_sozinha = 1;
        }
        if(cidade_sozinha==0)
        {
            if((sizeof(custoAERO)/sizeof(int))<i+1)
            {
                printf("Insuficienten");
                return EXIT_SUCCESS;
            }
        }
    }

该代码正常运行,但是当n的值太高时,我会在

中的sloc'ing时会遇到细分故障错误
    for (i = 0; i < N; i++) 
    {
        matriz_estradas[i] = malloc(sizeof(*matriz_estradas[i]));
    }

我可以在数组中提供最大的内存吗?

您需要更正此语句

matriz_estradas[i] = malloc(sizeof(*matriz_estradas[i]));

Matriz_estradas [i]尚未分配内存, *Matriz_estradas [i]尝试从未分配的内存

访问一个值

c 中是否有最大数组长度限制?您可以在此处阅读有关内存分配的信息,以及为什么您的代码无法使用,如果n为高号

相关内容

  • 没有找到相关文章

最新更新