将二维数组c[3][4]转换成一维数组[12]。

如题所述

假设你一维数组的大小为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个元素。
温馨提示:答案为网友推荐,仅供参考
相似回答