C语言 动态二维数组能否做函数参数?

我开辟了一个动态二维数组看下面源代码:#include<stdio.h>#include<malloc.h>voidmain(){voidsearch_1(float*p... 我开辟了一个动态二维数组 看下面源代码:
#include<stdio.h>
#include<malloc.h>
void main()
{
void search_1(float *p1,int n,int m);
int n,m,i,j,t;
float **a,b,*p=&b;
printf("please input row n(n<=40):\n");
scanf("%d",&n);
a=(float **)malloc(n*sizeof(float *));
printf("please input line m(m<=10):\n");
scanf("%d",&m);
for(t=0;t<m;t++)
a[t]=(float *)malloc(m*sizeof(float));
if(*a==NULL)
{
printf("out of menory,press any key to....");
exit(0);
}
printf("please input %d*%d numbers(grade):\n",n,m);
for(i=0;i<n;i++)
for(j=0;j<m;j++)
scanf("%f",&a[i][j]);
search_1(*a,n,m);
for(i=2;i>=0;i--)
free(a[i]);
free(a);

}

void search_1(float *p1,int n,int m)
{
int i;
float max=*p1;
for(i=1;i<m*n;i++)
if(*(p1+i)>max)
max=*(p1+i);
printf("max=a[%d][%d]=%.2f\n",(i-1)/m,(i-1)%m,max);
}

结果应该输出最大的一个数及下标,望高手指教!!!小弟感激不尽~~


展开
 我来答
chinlee1523
2010-04-05 · TA获得超过713个赞
知道小有建树答主
回答量:590
采纳率:0%
帮助的人:419万
展开全部
二级指针用的没有错,但是这两部分要换换位置
for(t=0;t<m;t++)
a[t]=(float *)malloc(m*sizeof(float));

if(*a==NULL)
{
printf("out of menory,press any key to....");
exit(0);
}
应该先检查申请二级指针内存成功与否再使用,而且应该是if(a==NULL),而不是if(*a==NULL)

void search_1(float *p1,int n,int m)
这个函数是想查找在这个方阵中的最大值吧?那么应该这样:
void search_1(float **p1,int n,int m)

里面怎么实现,你应该会的,你用二级指针很熟练的,理解很正确
冰火梦幻
2010-04-04 · TA获得超过2308个赞
知道小有建树答主
回答量:1095
采纳率:57%
帮助的人:448万
展开全部
void search_1(float *p1,int n,int m)
{
int i;
float max=*p1;
int maxindex = 0;

for(i=1;i<m*n;i++)
if(*(p1+i)>max)
{
max=*(p1+i);
maxindex = i;
}
printf("max=a[%d][%d]=%.2f\n",maxindex/m,maxindex%m,max);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2010-04-05
展开全部
#include<stdio.h>
#include<malloc.h>
void main()
{
void search_1(float **p1,int n,int m); //2级指针

int n,m,i,j,t;
float **a,b,*p=&b;
printf("please input row n(n<=40):\n");
scanf("%d",&n);
a=(float **)malloc(n*sizeof(float *));

printf("please input line m(m<=10):\n");
scanf("%d",&m);
for(t=0;t<m;t++)
a[t]=(float *)malloc(m*sizeof(float));

if(*a==NULL)
{
printf("out of menory,press any key to....");

}
printf("please input %d*%d numbers(grade):\n",n,m);
for(i=0;i<n;i++)
for(j=0;j<m;j++){
scanf("%f",&a[i][j]);
printf("%f ",a[i][j]);
}

search_1(a,n,m);//传入2级指针
for(i=2;i>=0;i--)
free(a[i]);
free(a);

}

void search_1(float **p1,int n,int m)//2级指针
{
int i,j;
float max=**p1;
printf("SIZE*SIZE:%d ",m*n);
for(i=0;i<n;i++){
for(j=0;j<m;j++){
if(*(*(p1+i)+j)>max)
max=*(*(p1+i)+j);//2级指针的使用方法
printf("()%f \n",*(*(p1+i)+j));
}
}
-------------------------------------------
原因:(float *)malloc(m*sizeof(float))获取的内存是连续的单元,但是你分2次来获取的内存就可能不是连续的单元。于是:简单的*(p1+i)就不能取出你的2维数组值。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式