码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2015-03-21 09:45:07      阅读:253      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!