输入一个二维数组 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