大佬帮我看看这串c语言代码……
这是输入一个3×4的矩阵,3行4列,然后会输出一个在行上最小,在列上最大的数。#include<stdio.h>#defineM3#defineN4intfun(int(...
这是输入一个3×4的矩阵,3行4列,然后会输出一个在行上最小,在列上最大的数。
#include<stdio.h>
#define M 3
#define N 4
int fun(int (*a)[N])
{
int Max, i, j, find, k;
i = 0;
while(i<M)
{
Max = a[i][0];
for(j=1; j<N; j++)
{
if(Max < a[i][j])
Max = a[i][j];
}
find = 1;
k = 0;
while(find && k<3)
{
if(Max < a[k][j])
k++;
else
{
find = 0;
break;
}
}
if(find != 0)
printf("the number is: \n a[%d][%d] = %d\n",i, j, a[i][j]);
else
printf(" no number!");
i++;
}
}
int main()
{
int zu[M][N];
int i,j;
for(i=0; i<M; i++)
{
for(j=0; j<N; j++)
{
scanf("%d", &zu[i][j]);
}
}
fun(zu);
return 0;
}
代码如上,我一次输入了
1 2 13 4
7 8 10 6
3 5 9 7这些数字。结果出来3个no number!
求大佬改正……按道理应该输出9啊…… 展开
#include<stdio.h>
#define M 3
#define N 4
int fun(int (*a)[N])
{
int Max, i, j, find, k;
i = 0;
while(i<M)
{
Max = a[i][0];
for(j=1; j<N; j++)
{
if(Max < a[i][j])
Max = a[i][j];
}
find = 1;
k = 0;
while(find && k<3)
{
if(Max < a[k][j])
k++;
else
{
find = 0;
break;
}
}
if(find != 0)
printf("the number is: \n a[%d][%d] = %d\n",i, j, a[i][j]);
else
printf(" no number!");
i++;
}
}
int main()
{
int zu[M][N];
int i,j;
for(i=0; i<M; i++)
{
for(j=0; j<N; j++)
{
scanf("%d", &zu[i][j]);
}
}
fun(zu);
return 0;
}
代码如上,我一次输入了
1 2 13 4
7 8 10 6
3 5 9 7这些数字。结果出来3个no number!
求大佬改正……按道理应该输出9啊…… 展开
2017-11-28
展开全部
如果是行上最小,列上最大,确实没有这个数,但是看代码明显与题意相反;
问题:1、
int fun(int (*a)[N])
{
int Max, i, j, find, k;
i = 0;
while(i<M)
{
Max = a[i][0];
for(j=1; j<N; j++)
{
if(Max < a[i][j])
Max = a[i][j];
}
find = 1;
k = 0;
while(find && k<3)
{
if(Max < a[k][j])//这个j的值应该是N-1,所以Max比较的是a[k][N-1],不一定是行最大值的那列的下标
k++;
else
{
find = 0;
break;
}
}
if(find != 0)
printf("the number is: \n a[%d][%d] = %d\n",i, j, a[i][j]);
else
printf(" no number!");
i++;
}
}
追问
说错了……应该是行上最大,列上最小……,应该怎么改,按你的改了一下还是三个no number!
追答
int fun(int (*a)[N])
{
int Max, i, j, find, k;
int flag = 0;
i = 0;
while(i<M)
{
Max = a[i][0];
for(j=1; j<N; j++)
{
if(Max < a[i][j])
{
Max = a[i][j];
flag = j;
}
}
find = 1;
k = 0;
while(find && k<3)
{
if(Max < a[k][falg])
k++;
else
{
find = 0;
break;
}
}
i++;
}
if(find != 0)
printf("the number is: \n a[%d][%d] = %d\n",i, j, a[i][j]);
else
printf(" no number!");
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询