7-74 二维数组处理(二) (6 分)
从键盘输入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>
#define n 6
int main()
{
double a[n][n];
int i,j,r,c;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
scanf("%lf",&a[i][j]);
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%5.2f",a[i][j]);
}
printf("\n");
}
r=0;
c=0;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
if(i>j)
a[i][j]-=1;
if(i<j)
a[i][j]+=1;
printf("%5.2f",a[i][j]);
if(a[i][j]>a[r][c])
{
c=j;
r=i;
}
}
printf("\n");
}
printf("The max is a[%d][%d] = %5.2f\n",r,c,a[r][c]);
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%5.2f",a[i][j]/a[r][c]);
}
printf("\n");
}
return 0;
}