gpt4 book ai didi

c - 了解此输入中的动态分配,c

转载 作者:太空宇宙 更新时间:2023-11-04 04:00:33 26 4
gpt4 key购买 nike

假设我想输入一个整数的平方。在每一行上,每对整数由一个空格分隔。所以下面的代码工作得很好:

//size of the square
int N;
scanf("%d",&N);
int **c;
c = malloc(N*sizeof(int*));

for (i=0;i<N;i++)
{ c[i] = malloc(2*sizeof(int));
for (j=0;j<2;j++)
{scanf("%d",&c[i][j]);}
}

所以在这里我不明白为什么没有考虑空间(所以它为什么有效 :-))?相反,如果我使用 n 数组 c[N][N],它就不会起作用,因为每个空格都会被解释为数组的输入

最佳答案

int N;
scanf("%d",&N);
int c[N][N]; /* Error */

c[][] 的大小必须在创建时已知。这意味着无法从输入中动态获取 N。

编辑:正如 Jonathan Leffler 所指出的,一些编译器支持在运行时确定数组大小。它是 C99 标准的一部分,但在随后的 C11 标准中它被设为可选。

虽然可选功能可能很棒,但它们会降低程序的可移植性。

关于c - 了解此输入中的动态分配,c,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12180052/

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