语法问题,请大佬看看
//输入5*5的数组,编写程序实现:1,求对角线上各元素之和。2,求出对角线上行、列下表均为偶数的各元素之积。3.找出对角线上其值最大的元素和他所在的数组中的位置。# include <stdio.h>
int main()
{
int a;
int i,j,k,sum1,sum2,sum;
for(i=0;i<5;i++)
{
for(j=0;j<5;j++)
{
scanf("%d",&a);
}
}
sum1=a+a+a+a+a;
sum2=a+a+a+a+a;
sum=sum1+sum2-a;
printf("该数组的对角线之和为:%d\n",sum);
int total;
total=a*a*a*a*a*a*
a*a*a;
printf("对角线上下标均为偶数的各元素的积为:%d\n",total);
int x,y,row=0,colum=0,max; //求最大值以及它所在数组中的位置
max=a;
for(x=0;x<5;x++)
for(y=0;y<5;y++)
if(a>max)
{
max=a;
row=i;
colum=j;
}
printf("最大值为:%d\n",max);
printf("在数组中的位置为第%d行,第%d列,是a[%d][%d]\n",row,colum,row,colum);
return 0;
}题目我已经在上面发了,前两问都能具体实现,但是到了第三步就出问题了,请大佬看看是哪一步没写对,我想输出的是最大值和最大值所在的位置,但是运行出来就会有问题,并不是我预期的那样。如果这个程序哪里还能优化的话,请大佬再指点一下,谢谢了。
#include <stdio.h>
typedef struct{
int n;
int r, c;
}value;
value max(int n, int arr){
value res = {-2147483648, -1, -1};
int a, b;
for(int i = 0, j = n-1; i < n; i++, j--){
a = arr;
b = arr;
if(res.n < a){ res.n = a; res.r = i; res.c = i; }
if(res.n < b){ res.n = b; res.r = j; res.c = i; }
}
return res;
}
int main()
{
int arr = {
{1, 2, 3, 4, 5},
{6, 7, 8, 9, 10},
{11, 12, 13, 14, 15},
{16, 17, 18, 19, 20},
{21, 22, 23, 24, 25}};
printf("max: %d\nrow: %d\ncolunm: %d", max(5, arr).n, max(5, arr).r, max(5, arr).c);
return 0;
}max: 25
row: 4
colunm: 4 在 本帖最后由 如来神掌 于 2021-12-20 15:46 编辑
傻眼貓咪 发表于 2021-12-19 18:02
学到了学到了,竟然是用的结构体,每次看你的回答都有收获。
页:
[1]