怎样将一维数组转换成二维数组 c【追加悬赏!】

来源:百度知道 编辑:UC知道 时间:2024/06/06 18:30:50
假如我已经声明并初始化了一个一维数组a[m*n],现在我想把这个数组转换成二维数组a[m][n],但是遗憾的是,(请注意)这里的m n都是需要用户手动输入的,也就是说他们都是不确定的值(这样声明二维数组时就会报错),那么我怎样将这个一维数组转换成二维数组呢?
转换成二维数组以后怎么才能用更简单的方式a[m][n]去表达呢?如果用那个表达式的话就太麻烦了,我要进行大量的操作,容易出问题。
打不出来中文直接打英文也行,我能看懂的,呵呵,谢谢啦

假设你一维数组的大小为100
你需要把它拆分为20*5的一个二维矩阵。

不妨这样去实现:
假设一维数组的下标为X,可以把它在逻辑上转换为二维数组的下标:
m = X / 5
n = X % 5

比如你要找第一行第二列的元素,那在一维数组中就是a[1]
转化为二维坐标就是b[0][1]。

其实多维数组和一维数组一样,在计算机中都是用的一段连续的内存。只是他们的表现形式不一样。

另外,C里边没有动态的二维数组,第二维的大小必须指定的。

问题补充:转换成二维数组以后怎么才能用更简单的方式a[m][n]去表达呢?如果用那个表达式的话就太麻烦了,我要进行大量的操作,容易出问题。
打不出来中文直接打英文也行,我能看懂的,呵呵,谢谢啦

答:这个可以用宏来实现。举个例子说,比如你定义一个大小为100的一维数组A,然后你需要别人输入m=8,n=9(很多情况别人不可能按照你的意图来刚好用m和n整除一维数组的下表最大值,也就是说那个一维数组只需要保证足够大就可以了),然后你希望得到一个8*9的二维矩阵B[8][9]。

引用这个二维矩阵的时候,直接使用B[3][4]来引用第三行第四列的元素?
用宏定义(以下宏定义并没有上机调试,只是提供思路)
#define B[(x)][(y)] A[((x*m)+(y%n)]
解释一下:x*m,加入你需要B[3][4],那么就是对应一维数组第3*8+4%9=28个元素。

float *a;
int m,n;

printf("Please input m and n:\n");
scanf("%d %d",&m,&n);
a = (float *) malloc(m*n*sizeof(float));
// a[m][n] m 是 Hang Shu, n 是 Lie Shu -> a[j][i]
一维数组a De Pai Lie:
for