从键盘输入6行6列的双精度型二维数组。
(1)按行输出二维数组每个元素的值。
(2)将上三角形每个元素的值加1,下三角形每个元素的值减1,对角线元素不变。按行输出二维数组每个元素的值。
(3)求变化后数组的最大值,按输出示例输出最大值的行列号和最大值。输出格式如下:
The max is a[最大值的行下标][最大值的列下标] = 最大值
(4)用数组每个元素除以最大值,得到新的数组并输出。
输出格式要求:输出的每个数字占5列,输出到小数点后2位,右对齐。
输入格式:
双精度二维数组a(6行6列)
输出格式:
按题目要求输出
输入样例:
1 3 5 6 9 3
8 9 7 5 3 3
1 2 3 5 9 7
3 5 6 2 4 6
3 5 2 1 0 5
8 9 5 4 3 1
输出样例:
1.00 3.00 5.00 6.00 9.00 3.00
8.00 9.00 7.00 5.00 3.00 3.00
1.00 2.00 3.00 5.00 9.00 7.00
3.00 5.00 6.00 2.00 4.00 6.00
3.00 5.00 2.00 1.00 0.00 5.00
8.00 9.00 5.00 4.00 3.00 1.00
1.00 4.00 6.00 7.0010.00 4.00
7.00 9.00 8.00 6.00 4.00 4.00
0.00 1.00 3.00 6.0010.00 8.00
2.00 4.00 5.00 2.00 5.00 7.00
2.00 4.00 1.00 0.00 0.00 6.00
7.00 8.00 4.00 3.00 2.00 1.00
The max is a[0][4] = 10.00
0.10 0.40 0.60 0.70 1.00 0.40
0.70 0.90 0.80 0.60 0.40 0.40
0.00 0.10 0.30 0.60 1.00 0.80
0.20 0.40 0.50 0.20 0.50 0.70
0.20 0.40 0.10 0.00 0.00 0.60
0.70 0.80 0.40 0.30 0.20 0.10
#include<stdio.h>
int main()
{
double a[6][6]={0};
double max=a[0][0];
int I=0,J=0;
//输入加第一次输出
for(int i=0;i<6;i++)
{
for(int j=0;j<6;j++)
{
scanf("%lf",&a[i][j]);
printf("%5.2lf",a[i][j]);
}
printf("\n");
}
//给上三角加一给下三角减一第二次输出,找出最大值
for(int i=0;i<6;i++)
{
for(int j=0;j<6;j++)
{
if(j>i)
{
a[i][j]+=1;
}
else if(i>j)
{
a[i][j]-=1;
}
printf("%5.2lf",a[i][j]);
//找出最大值
if(a[i][j]>max)
{
I=i;
J=j;
max=a[i][j];
}
}
printf("\n");
}
//输出最大值
printf("The max is a[%d][%d] = %.2lf\n",I,J,max);
//最后输出
for(int i=0;i<6;i++)
{
for(int j=0;j<6;j++)
{
a[i][j]/=max;
printf("%5.2lf",a[i][j]);
}
printf("\n");
}
return 0;
}