当前位置: 代码迷 >> C语言 >> 请教!动态二维数组
  详细解决方案

请教!动态二维数组

热度:272   发布时间:2008-04-17 23:09:48.0
请教!动态二维数组
请问怎么动态的为二维数组分配内存?
假设有一N行M列的数组array[N][M]
我的理解是把该数组看成有N个array[M]一维数组,定义一指针P1指向array,用mallco()为该数组分配动态内存。
然后定义一个指针数组*P2[N],该数组中的每个指针都指向一个一维数组
请问:
1、我这样理解对不对?
2、如果可以这样理解,那么怎么为该指针数组*p2[N]动态的分配内存?
3、若我的理解不对,请问该怎么为二维数组动态的分配内存?
(书上没具体说,不知道该如何操作。百度了一下,出来一大堆代码,没有说明,不理解)
自学C,刚接触到动态内存分配,很多地方都明白。
问题可能很弱智,请大家指教
搜索更多相关的解决方案: 动态  

----------------解决方案--------------------------------------------------------
你那种就是Java式的二维数组,是真二维,就那样就可以了
记得释放!


----------------解决方案--------------------------------------------------------
c++也支持区别是,通过指针实现,一个是引用..
----------------解决方案--------------------------------------------------------
能否举个例子
也就是为*P2[N]中的每个指针分配内存
用循环可以吗?
----------------解决方案--------------------------------------------------------
当然要循环


----------------解决方案--------------------------------------------------------
建议直接分配二维数组,好管理,省空间
int (*a)[20]=new int[10][20];
或者
int (&a)[10][20]=*(int(*)[10][20])new int [10][20];
其实前者就很好了,后者在sizeof上有优势……
----------------解决方案--------------------------------------------------------
谢谢!
大概明白了,回去再练练。
不知道还有没有更好的方法了?
----------------解决方案--------------------------------------------------------
6楼的方法有一个维的坐标被固定

我个人认为,借助C++类的运算符重载,把一维当成N维使用
会优美很多,不过,你得学C++

或者你干脆用STL的vector


----------------解决方案--------------------------------------------------------
fy的方法可以很灵活的分配数组,而我的方法则对低维有限定。
看你喜欢哪种了。
----------------解决方案--------------------------------------------------------
TO 6楼:
谢谢!我是不想把数组的维数限制住,想根据N和M的输入值来确定数组的大小。
( 这个想发源与飞燕的论坛上的一道题---N阶和幻方,因为N值不确定,所以就想到了动态分配)
----------------解决方案--------------------------------------------------------
  相关解决方案