gpt4 book ai didi

c - 数组的最大大小 - 段错误

转载 作者:行者123 更新时间:2023-11-30 19:09:07 27 4
gpt4 key购买 nike

我的代码遇到一些问题:

#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("Insuficiente\n");
return EXIT_SUCCESS;
}
}
}

代码工作正常,但是当 N 的值太高时,在分配时会出现段错误错误

    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 - 数组的最大大小 - 段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43737467/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com