关于动态二维数组
首先我int*p=(int*)malloc(peoplen*subjectn*sizeof(int));分配一内存,然后这样操作for(i=0;i<peoplen;i++...
首先我int *p=(int *)malloc(peoplen*subjectn*sizeof(int));分配一内存,然后这样操作
for(i=0;i<peoplen;i++)
for(j=0;j<subjectn;j++)
scanf("%d",&p[i][j]);
请问错在哪里了,应该怎么改。积分不高,只能给10分表点心意了。 展开
for(i=0;i<peoplen;i++)
for(j=0;j<subjectn;j++)
scanf("%d",&p[i][j]);
请问错在哪里了,应该怎么改。积分不高,只能给10分表点心意了。 展开
5个回答
展开全部
我是这样理解的:
我是这样理解的:
就一个二维数组,它的每行都可看做是一个一维数组,比如:int a[2][3],如果把它的第一行都看作包含3个元素的一维数组话,我们可以定以一个int *p1指针指向这个二维数组的第一行,同样我们可以再定义一个int *p2指向第二行。为了方便,我们不妨把p1和p2这两个指针放在一个指针数组中即int *p[2],这样我们可以再定义一个二级指针int **q,指向这个int *p[2],这样我们就可以通过指针很方便的访问这个二维数组中的每个元素了
如果给一个二维数组动态分配行列数为m行、n列,可以这样:先分配行,再分配列。比如:m行、n列;先分配一个有m个元素的一维数组,数组的每个元素是个指针(即:int *),并且分别指向m行,再给每行分配n*sizeof(int)就可以了。
参考程序:
#include <stdio.h>
#include <malloc.h>
int main()
{
int i,j;
int peoplen,subjectn;
int **p=NULL;
scanf("%d%d",&peoplen,&subjectn);
p=(int **)malloc(peoplen*sizeof(int*));
for(i=0;i<peoplen;i++)
{
p[i]=(int *)malloc(subjectn*sizeof(int));
}
for(i=0;i<peoplen;i++)
{
for(j=0;j<subjectn;j++)
{
scanf("%d",&p[i][j]);
}
}
for(i=0;i<peoplen;i++)
{
for(j=0;j<subjectn;j++)
{
printf("%5d",p[i][j]);
}
printf("\n");
}
for(i=0;i<peoplen;i++)
{
free(p[i]);
p[i]=NULL;
}
free(p);
p=NULL;
return 0;
}
我是这样理解的:
就一个二维数组,它的每行都可看做是一个一维数组,比如:int a[2][3],如果把它的第一行都看作包含3个元素的一维数组话,我们可以定以一个int *p1指针指向这个二维数组的第一行,同样我们可以再定义一个int *p2指向第二行。为了方便,我们不妨把p1和p2这两个指针放在一个指针数组中即int *p[2],这样我们可以再定义一个二级指针int **q,指向这个int *p[2],这样我们就可以通过指针很方便的访问这个二维数组中的每个元素了
如果给一个二维数组动态分配行列数为m行、n列,可以这样:先分配行,再分配列。比如:m行、n列;先分配一个有m个元素的一维数组,数组的每个元素是个指针(即:int *),并且分别指向m行,再给每行分配n*sizeof(int)就可以了。
参考程序:
#include <stdio.h>
#include <malloc.h>
int main()
{
int i,j;
int peoplen,subjectn;
int **p=NULL;
scanf("%d%d",&peoplen,&subjectn);
p=(int **)malloc(peoplen*sizeof(int*));
for(i=0;i<peoplen;i++)
{
p[i]=(int *)malloc(subjectn*sizeof(int));
}
for(i=0;i<peoplen;i++)
{
for(j=0;j<subjectn;j++)
{
scanf("%d",&p[i][j]);
}
}
for(i=0;i<peoplen;i++)
{
for(j=0;j<subjectn;j++)
{
printf("%5d",p[i][j]);
}
printf("\n");
}
for(i=0;i<peoplen;i++)
{
free(p[i]);
p[i]=NULL;
}
free(p);
p=NULL;
return 0;
}
展开全部
你的问题其实很简单,我稍微说下我的思路:
首先你定义了一个整型指针,然后使用这个整型指针动态分配了peoplen*subjectn个整型空间,那么这个指针则指向了这个动态分配的空间的首地址。
同时要注意这个指针是一个一级指针,但是你在for嵌套循环中却将他以二级指针的形式表现出来了。
scanf("%d",&p[i][j]);这个是二级指针。先前没定义,那么后面编译的时候就自然报错了。
改进方法:
for(i=0;i<peoplen;i++)
for(j=0;j<subjectn;j++)
scanf("%d",&p[i*subjectn+j]);
首先你定义了一个整型指针,然后使用这个整型指针动态分配了peoplen*subjectn个整型空间,那么这个指针则指向了这个动态分配的空间的首地址。
同时要注意这个指针是一个一级指针,但是你在for嵌套循环中却将他以二级指针的形式表现出来了。
scanf("%d",&p[i][j]);这个是二级指针。先前没定义,那么后面编译的时候就自然报错了。
改进方法:
for(i=0;i<peoplen;i++)
for(j=0;j<subjectn;j++)
scanf("%d",&p[i*subjectn+j]);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不同意一楼的,我看按你写的题目应该是scanf("%d",p+i*peoplen+j);
int *p,代表p是一维指针,p[i][j]代表p是二维指针,一维当二维用当然不对
建议你再看看,指针与数组的知识
int *p,代表p是一维指针,p[i][j]代表p是二维指针,一维当二维用当然不对
建议你再看看,指针与数组的知识
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
编译时没法确定行偏移是多少吧
即p[i][j]没法parse成p + NLINE * i + j的形式,NLINE不能确定
如果要改,建议直接把二维的[i][j]映射到红果果的基址+变址
即p[i][j]没法parse成p + NLINE * i + j的形式,NLINE不能确定
如果要改,建议直接把二维的[i][j]映射到红果果的基址+变址
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
scanf("%d",p+i*subjectn+j);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询