在c语言中,动态创建二维数组的问题
数组的行和列是可以变化的那种二维数组。创建二维数组,最好是写成函数的那种形式,我也不知道能不能写成函数形式,这样用起来比较方便吧。释放二维数组的内存,最好也写成函数形式的...
数组的行 和 列 是可以变化的那种二维数组。
创建二维数组,最好是写成函数的那种形式,我也不知道能不能写成函数形式,这样用起来比较方便吧。
释放二维数组的内存,最好也写成函数形式的。
http://zhidao.baidu.com/question/112765442.html 展开
创建二维数组,最好是写成函数的那种形式,我也不知道能不能写成函数形式,这样用起来比较方便吧。
释放二维数组的内存,最好也写成函数形式的。
http://zhidao.baidu.com/question/112765442.html 展开
3个回答
展开全部
简单点的方法是用1维数组模拟二维数组
int m,n;//m为行, n为列
scanf("%d %d", &m, &n);
int *arr = (int*)malloc(m * n)
使用方法是
如果要访问(i, j)元素 arr[i * m + j]
释放的话 free(arr)
这个思路是基于二维数组在内存中其实也是连续存储的, 只是他有指向指针的指针数组可以方便操作所以用一位数组模拟二维数组是比较简单的思路
用二维数组的话
int m,n;//m为行, n为列
scanf("%d %d", &m, &n);
int **arr = (int**)malloc(m);
for (int i = 0; i < m; ++i)
{
arr[i] = (int*)malloc(n);
}
释放这样释放
for (int i = 0; i < m; ++i)
{
free(arr[i]);
}
int m,n;//m为行, n为列
scanf("%d %d", &m, &n);
int *arr = (int*)malloc(m * n)
使用方法是
如果要访问(i, j)元素 arr[i * m + j]
释放的话 free(arr)
这个思路是基于二维数组在内存中其实也是连续存储的, 只是他有指向指针的指针数组可以方便操作所以用一位数组模拟二维数组是比较简单的思路
用二维数组的话
int m,n;//m为行, n为列
scanf("%d %d", &m, &n);
int **arr = (int**)malloc(m);
for (int i = 0; i < m; ++i)
{
arr[i] = (int*)malloc(n);
}
释放这样释放
for (int i = 0; i < m; ++i)
{
free(arr[i]);
}
展开全部
typedef int (*a)[5] ;
int main ()
{
int b[100] ;
b[47] = 2500 ;
printf ("%d" ,((a)b)[9][2]) ;
return 0 ;
}
/*
别想了,这种想法永远学不好c语言,[]对于c语言来说是地址运算符,c语言只有格式化访问地址这一做法,不管你喜不喜欢,上面的代码能理解多少就是多少吧
*/
int main ()
{
int b[100] ;
b[47] = 2500 ;
printf ("%d" ,((a)b)[9][2]) ;
return 0 ;
}
/*
别想了,这种想法永远学不好c语言,[]对于c语言来说是地址运算符,c语言只有格式化访问地址这一做法,不管你喜不喜欢,上面的代码能理解多少就是多少吧
*/
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <stdlib.h>
int *create(int n,int m){ //创建
int *root=(int*)malloc(m*n*sizeof(int));
return root;
}
int get_value(int *arr,int n,int m,int i,int j){ //获取值
if(i<0 || i>n) return 0;
if(j<0 || j>m) return 0;
return i*m+j;
}
void free_arr(int *arr){ //释放
free(arr);
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询