PTA 7-297 二维数组处理(二)
分数 10
作者 伍建全
单位 重庆科技学院
从键盘输入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
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
#include<stdio.h>
#define n 6
int main(){
double Arr[n][n];
int i, j;
int r, c; //记录数组下标
//遍历数组
for(i = 0; i < n; i++){
for(j = 0; j < n; j++){
scanf("%lf", &Arr[i][j]);
}
}
//输出数组
for(i = 0; i < n; i++){
for(j = 0; j < n; j++){
printf("%5.2f", Arr[i][j]); //占5位且保留两位小数
}
printf("\n");
}
r = 0;
c = 0;
//处理上三角形和下三角形的格式
for(i = 0;i < n; i++){
for(j = 0; j < n; j++){
if(i > j)
Arr[i][j] -= 1;
if(i < j)
Arr[i][j] += 1;
printf("%5.2f", Arr[i][j]);
if(Arr[i][j] > Arr[r][c]){
c = j;
r = i;
}
}
printf("\n");
}
//求变化后数组的最大值
printf("The max is a[%d][%d] = %5.2f\n",r , c, Arr[r][c]);
//数组每个元素除以最大值
for(i = 0; i < n; i++){
for(j = 0; j < n; j++){
printf("%5.2f", Arr[i][j]/Arr[r][c]);
}
printf("\n");
}
return 0;
}
解题思路:
按照题目要求一步一步完成即可
归属知识点:
数组
循环结构