首页 > 编程语言 > 详细

动态内存分配连续内存空间的二维数组

时间:2015-03-21 09:41:54      阅读:483      评论:0      收藏:0      [点我收藏+]

可以直接使用一维数组来模拟二维数组,下面的代码就是在此基础上,用一个二级指针指向一维数组的相应地方,详见代码

#include <stdio.h>
#include <malloc.h>

int main()
{
    int row,col,i,j,n=0;
    row=col=3;
//malloc连续内存的二维数组
    int **arr=(int**)malloc(row*sizeof(int*));//分配二维数组
    arr[0]=(int*)malloc(row*col*sizeof(int));//分配一维数组
    for(i=1;i<row;i++)
        arr[i]=arr[i-1]+col;
//分配结束
    for(i=0;i<row;i++)
           for(j=0;j<col;j++)
               printf("地址%2d:  %d\n",n++,&arr[i][j]);
    free(arr[0]);
    free(arr);
    return 0;

}

 

动态内存分配连续内存空间的二维数组

原文:http://www.cnblogs.com/onestow/p/4355150.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!