SCAU:18062 二维数组每行中的最大值

2023-12-20 17:41:13

18062?二维数组每行中的最大值

时间限制:1000MS? 代码长度限制:10KB
提交次数:0 通过次数:0

题型: 填空题???语言: G++;GCC;VC

Description

输入一个4*4的二维整型数组,使用指针变量查找并输出二维整型数组中每一行的最大值。


#include?<stdio.h>

void?find(int?a[][4])
{
????int?(*p)[4],?*q,?*max;
????for(_______________________)
????{
????????max=*p;
????????for(_______________________)
????????{
_______________________
????????}
????????printf("%d\n",?*max);
????}
}

int?main()
{
????int?a[4][4],i,j;
????for(i=0;?i<4;?i++)
????????for(j=0;?j<4;?j++)
????????????scanf("%d",?&a[i][j]);
????find(a);
????return?0;
}

?

输入格式

4*4的整数矩阵


?

输出格式

每行最大值,一行一个

输入样例

1 2 3 4
8 7 6 5
1 1 1 1
2 2 2 2

输出样例

4
8
1
2
#include <stdio.h>

void find(int a[][4])
{
    int (*p)[4], *q, *max;
    for(p=a;p<a+4;p++)//p初始存的是a的地址,*p是a[0][0]的值
    {
        max=*p;//max存的是*p的地址
        for(q=*p;q<*p+4;q++)//q初始存的是*p的地址,注意区分*p+4和*(p+4)
        {
            if(*q>*max)//第一次循环*q和*max是*p的值即a[0][0]
            max=q;
        }
        printf("%d\n", *max);
    }
}

int main()
{
    int a[4][4],i,j;
    for(i=0; i<4; i++)
        for(j=0; j<4; j++)
            scanf("%d", &a[i][j]);
    find(a);
    return 0;
}

?

文章来源:https://blog.csdn.net/zero_019/article/details/135109919
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。