| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 423 人关注过本帖
标题:一个关于二维数组动态分配空间的问题!!!!!!!!!!!!!!!!!!!!!!!!
只看楼主 加入收藏
aa511950071
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2012-11-23
结帖率:50%
收藏
 问题点数:0 回复次数:2 
一个关于二维数组动态分配空间的问题!!!!!!!!!!!!!!!!!!!!!!!!
#include<stdio.h>
#include<stdlib.h>
int main()
{
    int i,j,n;
    int **p;
    p=(int **)malloc(sizeof(int)*20);
    if(p==NULL)
    {               
        printf("fail!\n");
        return;
    }
    //分配p[n]的地址 也就是行数
    for(n=0;n<4;n++)
    {
        *(p+n)=(int *)malloc(sizeof(int)*n*5);        //*5是因为一行有5个元素
    }
    for(n=0;n<4;n++)
    {
        if(p[n]==NULL)
        {
            printf("fail!\n");
            return;
        }
    }
    //初始化一个4行5列的数组
    for(i=0;i<4;i++)
    {
        for(j=0;j<5;j++)
        {
            *(*(p+i)+j)=i+j;
        }
    }
   
    for(i=0;i<4;i++)
    {
        for(j=0;j<5;j++)
        {
            printf("%d\t",p[i][j]);
        }
        printf("\n");
    }
    return 0;   
}
运行GCC  编译出的结果是     0 1 2 3 1
                            1 2 3 4 5
                            2 3 4 5 6
                            3 4 5 6 7

为啥 p[0][4]  不是我想的4  而是1   求大神指教!!!!!!!!
搜索更多相关主题的帖子: include return 动态 
2012-11-25 19:12
Mrrr
Rank: 2
等 级:论坛游民
帖 子:15
专家分:72
注 册:2012-9-4
收藏
得分:0 
*n是什么意思阿?,一维数组是不是后面比前面多5个(int)?(求解?)
2012-11-25 22:24
lxsjzbd
Rank: 4
来 自:河北省
等 级:业余侠客
帖 子:97
专家分:258
注 册:2012-3-31
收藏
得分:0 
我这儿运行是4
不过你二维数组分配的有问题
1,列值固定时:int **p=(int **)malloc(sizeof(int)*ROW*5);  (你这儿ROW=4)
               int (*ps)[5]=(int(*)[5])p;    ps就是二维数组首地址
2,行列任意的但是内存不连续的:
               int **p=(int **)malloc(sizeof(int *)*ROW);
               for(int i=0;i<ROW;i++)
              {
                  p[i]=(int *)malloc(sizeof(int)*COL);      
               }
                p就是二维数组首地址
3,行列任意的但是内存也连续的:
               int **arr=(int **)malloc(sizeof(int *)*ROW+sizeof(int)*ROW*COL);
               int *phead=(int *)((int)arr+sizeof(int *)*ROW);
               for(int i=0;i<ROW;i++)
               {
                    arr[i]=(int *)((int)phead+sizeof(int)*ROW*COL);
                }
                arr[0]就是第0行的首地址
注意别忘了free。。。。。。。。。。。
2012-11-26 09:48
快速回复:一个关于二维数组动态分配空间的问题!!!!!!!!!!!!!!!!!!!!!!!!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015491 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved