PTA 7-297 二维数组处理(二)

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;
}

解题思路:
按照题目要求一步一步完成即可

归属知识点:
数组
循环结构

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值