我有这个功能
int findMax(int **a,int row,int column)
我正在使用2-d数组a[10][10]
。
现在该怎么做才能将这个数组的地址传递给**a
的函数指针?
我看到其他答案,但问题仍然是相同的,我必须传递地址,但每当我尝试这样做,我的编译器开始给出错误,并说不能将int转换为int和类型不匹配错误。 我必须使用只有** a。
的功能给我你宝贵的建议和想法,我该怎么做?
这是我的代码。
#include<stdio.h>
int findMax(int **a,int r,int c);
int main()
{
int a[10][10],i,j,mx,r,c;
printf("Enter the number of rows in the matrix\n");
scanf("%d",&r);
printf("Enter the number of columns in the matrix\n");
scanf("%d",&c);
printf("Enter the elements in the matrix\n");
for(i=1;i<=r;i++)
{
for(j=1;j<=c;j++)
scanf("%d",&a[i][j]);
}
printf("The matrix is\n");
for(i=1;i<=r;i++)
{
for(j=1;j<=c;j++)
printf("%d ",a[i][j]);
printf("\n");
}
printf("\n");
mx=findMax((*a)[10],r,c);
printf("The maximum elements in the matrix is %d\n",mx);
return 0;
}
int findMax(int **a,int r,int c)
{
int t,i,j;
t=a[1][1];
for(i=1;i<=r;i++)
{
for(j=1;j<=c;j++)
{
if(a[i][j]>t)
t=a[i][j];
}
}
return (t);
答案 0 :(得分:0)
您可以将功能定义为
int findMax( int ( *a )[10], int r );
或喜欢
int findMax( int r, int c, int ( *a )[c] );
如果编译器支持C99,则最后一个声明是可用的。
考虑到该功能有拼写错误。而不是
t=a[1][1];
必须有
t=a[0][0];
或者这些循环
for(i=1;i<=r;i++)
{
for(j=1;j<=c;j++)
必须像
一样写for(i=0;i < r;i++)
{
for(j=0; j < c;j++)
主要存在同样的问题。例如,而不是
for(i=1;i<=r;i++)
{
for(j=1;j<=c;j++)
scanf("%d",&a[i][j]);
}
你必须写
for ( i = 0;i < r; i++ )
{
for ( j = 0; j < c; j++ )
scanf("%d",&a[i][j]);
}
因为C中的索引从0开始。
如果您的编译器支持C((那么程序可能看起来像
)#include <stdio.h>
int findMax( int r, int c, int a[r][c] )
{
int max = a[0][0];
for ( int i = 0; i < r; i++ )
{
for ( int j = 0; j < c; j++ )
{
if ( max < a[i][j] ) max = a[i][j];
}
}
return max;
}
int main(void)
{
int r, c;
printf( "Enter the number of rows in the matrix: " );
scanf( "%d", &r );
printf( "Enter the number of columns in the matrix: " );
scanf( "%d", &c );
int a[r][c];
for ( int i = 0; i < r; i++ )
{
for ( int j = 0; j < c; j++ )
{
scanf( "%d", &a[i][j] );
}
}
printf( "The matrix is\n" );
for ( int i = 0; i < r; i++ )
{
for ( int j = 0; j < c; j++ ) printf( "%d ", a[i][j] );
printf( "\n" );
}
printf( "\n" );
int mx = findMax( r, c, a );
printf( "The maximum elements in the matrix is %d\n", mx );
return 0;
}
否则,您可以动态分配数组。例如
#include <stdio.h>
#include <stdlib.h>
int findMax( int **a, int r, int c )
{
int i, j;
int max = a[0][0];
for ( i = 0; i < r; i++ )
{
for ( j = 0; j < c; j++ )
{
if ( max < a[i][j] ) max = a[i][j];
}
}
return max;
}
int main(void)
{
int r, c;
int i, j;
int **a;
int mx;
printf( "Enter the number of rows in the matrix: " );
scanf( "%d", &r );
printf( "Enter the number of columns in the matrix: " );
scanf( "%d", &c );
a = ( int ** )malloc( r * sizeof( int * ) );
for ( i = 0; i < r; i++ ) a[i] = ( int * )malloc( c * sizeof( int ) );
for ( i = 0; i < r; i++ )
{
for ( j = 0; j < c; j++ )
{
scanf( "%d", &a[i][j] );
}
}
printf( "The matrix is\n" );
for ( i = 0; i < r; i++ )
{
for ( j = 0; j < c; j++ ) printf( "%d ", a[i][j] );
printf( "\n" );
}
printf( "\n" );
mx = findMax( a, r, c );
printf( "The maximum elements in the matrix is %d\n", mx );
for ( i = 0; i < r; i++ ) free( a[i] );
free( a );
return 0;
}