c中的二维动态int数组
2d dynamic int array in c
我想创建一个函数,将给定的二维动态 int 数组增加一行。我看了几个网站,指南,教程,但都是不同的,所以我现在很困惑。
二维数组有 2 个固定列。
我的代码在这里:
int length=1;
void arrayinc(int** array, int x0, int x1)
{
if (array == NULL)
malloc(array, sizeof(int[2]));
else
realloc(array, (++length)*sizeof(int[2]));
array[length-1][0]=x0;
array[length-1][1]=x1;
free(array);
}
int main()
{
int** array=NULL;
arrayinc(&array, 1, 2);
// I will do some stuff after the increase
}
我希望有人能帮助我,并解释它是如何工作的!
对不起我的英语和糟糕的malloc/realloc知识。
函数参数是它的局部变量。所以在函数中你处理原始参数的副本。
至少参数应该声明为
int*** array
如果列数是一个 compile-time 常量,则函数可以按以下方式定义。
#include <stdio.h>
#include <stdlib.h>
#define N 2
size_t arrayinc( int ( **array )[N], size_t n, int x0, int x1)
{
int ( *tmp )[N] = realloc( *array, ( n + 1 ) * sizeof( int[N] ) );
if ( tmp )
{
*array = tmp;
( *array )[n][0] = x0;
( *array )[n][1] = x1;
++n;
}
return n;
}
int main(void)
{
int ( *array )[N] = NULL;
size_t n = 0;
for ( size_t i = 0; i < 10; i++ )
{
n = arrayinc( &array, n, ( int )( 2 * i ), ( int )( 2 * i + 1 ) );
}
for ( size_t i = 0; i < n; i++ )
{
printf( "%d\t%d\n", array[i][0], array[i][1] );
}
free( array );
return 0;
}
程序输出为
0 1
2 3
4 5
6 7
8 9
10 11
12 13
14 15
16 17
18 19
我想创建一个函数,将给定的二维动态 int 数组增加一行。我看了几个网站,指南,教程,但都是不同的,所以我现在很困惑。
二维数组有 2 个固定列。
我的代码在这里:
int length=1;
void arrayinc(int** array, int x0, int x1)
{
if (array == NULL)
malloc(array, sizeof(int[2]));
else
realloc(array, (++length)*sizeof(int[2]));
array[length-1][0]=x0;
array[length-1][1]=x1;
free(array);
}
int main()
{
int** array=NULL;
arrayinc(&array, 1, 2);
// I will do some stuff after the increase
}
我希望有人能帮助我,并解释它是如何工作的!
对不起我的英语和糟糕的malloc/realloc知识。
函数参数是它的局部变量。所以在函数中你处理原始参数的副本。
至少参数应该声明为
int*** array
如果列数是一个 compile-time 常量,则函数可以按以下方式定义。
#include <stdio.h>
#include <stdlib.h>
#define N 2
size_t arrayinc( int ( **array )[N], size_t n, int x0, int x1)
{
int ( *tmp )[N] = realloc( *array, ( n + 1 ) * sizeof( int[N] ) );
if ( tmp )
{
*array = tmp;
( *array )[n][0] = x0;
( *array )[n][1] = x1;
++n;
}
return n;
}
int main(void)
{
int ( *array )[N] = NULL;
size_t n = 0;
for ( size_t i = 0; i < 10; i++ )
{
n = arrayinc( &array, n, ( int )( 2 * i ), ( int )( 2 * i + 1 ) );
}
for ( size_t i = 0; i < n; i++ )
{
printf( "%d\t%d\n", array[i][0], array[i][1] );
}
free( array );
return 0;
}
程序输出为
0 1
2 3
4 5
6 7
8 9
10 11
12 13
14 15
16 17
18 19