看起来没问题,实际上有问题,就是函数实参和形参值改变的问题,你的函数f只是改变了形参的值,实参Z数组的值根本没变,所以你运行f(x,y,z)之后,Z数组的值没变,依然是声明时的值,加上你的Z数组又没赋初值,当然输出Z会是一堆随机数了,看上去就是乱码。你的f函数要改下。把Z数组声明为全局变量就行了,完整修改如下:
#include
int z[3][4];
int f(int x[3][4], int y[3][4])
{
int i,j,p=2;//这个p你还要赋值,不然怎么知道是多少,根据你题的要求来赋值,我设为2
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
z[i][j]=p*x[i][j]-y[i][j];
}
}
int main()
{
int i,j,x[3][4],y[3][4],z[3][4];
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
scanf("%d",&x[i][j]);
}
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
scanf("%d",&y[i][j]);
}
f(x,y,z);
for (i=0;i<3;i++)
{
for(j=0;j<4;j++)
printf("%d",z[i][j]);
}
}
这样就行了,
f函数有问题,f中p可以分到变量中(也可在函数中赋值),否则p没有赋值是没有结果的,在z数组为返回值,不能加在输入变量中。
另外,为了调试方便,可以把主函数中数组长度设小一些,等调试正确了,在改成需要的长度,你说24个数值要输多久。
#include
int z[3][4]; /*定义z*/
int f(int x[3][4], int y[3][4],int p) /*把p当做变量,z作输出*/
{
int i,j;
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
z[i][j]=p*x[i][j]-y[i][j];
return z[3][4]; /*返回z,你少了这步*/
}
}
int main()
{
int i,j,x[3][4],y[3][4];
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
scanf("%d",&x[i][j]);
}
for(i=0;i<3;i++)
{
for(j=0;j<4;j++)
scanf("%d",&y[i][j]);
}
f(x,y,1); /*调用f函数,并给p赋值*/
for (i=0;i<3;i++)
{
for(j=0;j<4;j++)
printf("%d",z[i][j]);
}
}
f函数p的值未知