二维数组处理(二)

从键盘输入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

C程序如下:

#include 

int main(void)
{
    double a[6][6];
    int i, j;
    for(int i = 0; i < 6; i++)
    {
        for(int j = 0; j < 6; j++)
        {
            scanf("%lf", &a[i][j]);
        }
    }
    for(int i = 0; i < 6; i++)
    {
        for(int j = 0; j < 6; j++)
        {
            printf(" %.2lf", a[i][j]);
        }
        printf("\n");
    }
    for(int i = 0; i < 6; i++)
    {
        for(int j = 0; j < i; j++)
        {
            if(i != j)
            {
                a[i][j] -= 1;
            }
        }
    }
    for(int i = 0; i < 6; i++)
    {
        for(int j = i; j < 6; j++)
        {
            if(i != j)
            {
                a[i][j] += 1;
            }
        }
    }
    for(int i = 0; i < 6; i++)
    {
        for(int j = 0; j < 6; j++)
        {
            printf("%5.2lf", a[i][j]);
        }
        printf("\n");
    }
        double max = a[0][0];
    int x, y;
    for(int i = 0; i < 6; i++)
    {
        for(int j = 1; j < 6; j++)
        {
            if(max < a[i][j])
            {
                max = a[i][j];
                x = i;
                y = j;
            }
        }
    }
    printf("The max is a[%d][%d] = %.2lf", x, y, max);
    printf("\n");
    for(int i = 0; i < 6; i++)
    {
        for(int j = 0; j < 6; j++)
        {
            printf(" %.2lf", a[i][j] / max);
        }
        printf("\n");
    }
    return 0;
}

你可能感兴趣的:(算法,数据结构)