AcWing 747. 数组的左上半部分

输入一个二维数组 M[12][12]M[12][12],根据输入的要求,求出二维数组的左上半部分元素的平均值或元素的和。

左上半部分是指次对角线上方的部分,如下图所示,黄色部分为对角线,绿色部分为左上半部分:

输入格式

第一行输入一个大写字母,若为 S,则表示需要求出左上半部分的元素的和,若为 M,则表示需要求出左上半部分的元素的平均值。

接下来 1212 行,每行包含 1212 个用空格隔开的浮点数,表示这个二维数组,其中第 i+1i+1 行的第 j+1j+1 个数表示数组元素 M[i][j]。

输出格式

输出一个数,表示所求的平均数或和的值,保留一位小数。

数据范围

−100.0≤M[i][j]≤100.0−100.0≤M[i][j]≤100.0

输入样例:

M
-0.4 -7.7 8.8 1.9 -9.1 -8.8 4.4 -8.8 0.5 -5.8 1.3 -8.0
-1.7 -4.6 -7.0 4.7 9.6 2.0 8.2 -6.4 2.2 2.3 7.3 -0.4
-8.1 4.0 -6.9 8.1 6.2 2.5 -0.2 -6.2 -1.5 9.4 -9.8 -3.5
-2.3 8.4 1.3 1.4 -7.7 1.3 -2.3 -0.1 -5.4 -7.6 2.5 -7.7
6.2 -1.5 -6.9 -3.9 -7.9 5.1 -8.8 9.0 -7.4 -3.9 -2.7 0.9
-6.8 0.8 -9.9 9.1 -3.7 -8.4 4.4 9.8 -6.3 -6.4 -3.7 2.8
-3.8 5.0 -4.6 2.0 4.0 9.2 -8.9 0.5 -3.9 6.5 -4.3 -9.9
-7.2 6.2 -1.2 4.1 -7.4 -4.6 4.7 -0.4 -2.2 -9.1 0.4 -5.8
9.1 -6.4 9.2 0.7 10.0 -5.7 -9.7 -4.4 4.7 4.7 4.9 2.1
-1.2 -6.2 -8.2 7.0 -5.3 4.9 5.5 7.2 3.4 3.2 -0.2 9.9
-6.9 -6.2 5.1 8.5 7.1 -0.8 -0.7 2.7 -6.0 4.2 -8.2 -9.8
-3.5 7.7 5.4 2.8 1.6 -1.0 6.1 7.7 -6.5 -8.3 -8.5 9.4
输出样例:

-0.8

代码思路:

/*代码思路:
        1).先定义一个字符判断数组求和是否需要求平均值
        2).定义浮点型二维数组double a[12][12]并用循环赋值
        3).通过图来观察绿色方格个数与行列的关系,发现并找到规律
        4).定义sum存储数组(绿色方格)求和
        5).定义sum1存储数组(绿色方格)个数之和
*/

#include <iostream>

using namespace std;

int main()
{
    char ch;
    cin>>ch;
    double a[12][12];//注意题意是浮点型数组
    for(int i=0; i<12; i++)
    {
        for(int j=0; j<12; j++)
        {
            scanf("%lf ", &a[i][j]);//存储二维数组元素
        }
    }
    double sum = 0.0, sum1=0.0;
    for(int i=0; i<11; i++)
    {
        //通过行列来找规律
        for(int j=0; j<=10-i; j++)
        {
            sum+=a[i][j];//定义sum存储绿色方格的数组求和
        }
    }
    for(int i=1; i<12; i++)
    {
        sum1+=i;//定义sum存储绿色方格数组总个数
    }
    if(ch=='S')
    {
        //若字符==S,则求元素的和
        printf("%.1lf\n", sum);
    }
    else
    {
        //否则,求所求元素总和的平均值
        printf("%.1lf\n", sum/sum1);
    }
    return 0;
}

 小伙伴们如果有更好的解法可以在评论区讨论哦

最后,代码一定要自己写,一定要独立思考哦

————————————————
版权声明:本文为CSDN博主「踏云归h~」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_72949008/article/details/127559943

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值