【C语言】计算3x3矩阵每行的最大值并存入第四列

文章目录


代码

c 复制代码
#include <stdio.h>

int main() {
    int a[3][4]; // 定义一个3行4列的二维数组
    int i, j, max;

    printf("请输入一个3行3列的矩阵,每输入一个元素后按回车键:\n");

    // 读取用户输入的3x3矩阵
    for (i = 0; i < 3; i++) {
        for (j = 0; j < 3; j++) {
            scanf("%d", &a[i][j]);
        }
    }

    // 计算每行的最大值并存储在第四列
    for (i = 0; i < 3; i++) {
        max = a[i][0]; // 假设每行的第一个元素是最大值
        for (j = 1; j < 3; j++) { 
            if (max < a[i][j]) { 
                max = a[i][j]; // 更新最大值
            }
        }
        a[i][3] = max; // 将最大值存储在第四列
    }
    
    // 输出原始矩阵及每行的最大值
    printf("输入的矩阵及每行的最大值:\n");
    for (i = 0; i < 3; i++) {
        for (j = 0; j < 4; j++) { 
            printf("%d ", a[i][j]);
        }
        printf("\n");
    }

    return 0;
}

解释

  1. 数组定义 :我们定义了一个3行4列的二维数组a[3][4],用于存储矩阵元素及其每行的最大值。

  2. 输入矩阵:通过两层嵌套循环,我们读取用户输入的3x3矩阵。外层循环控制行,内层循环控制列。

  3. 计算最大值:对于每一行,我们首先假设第一个元素是最大值,然后通过内层循环遍历该行的其他元素,使用条件判断更新最大值。

  4. 存储最大值:将每行计算出的最大值存储在该行的第四列。

  5. 输出结果 :最后,我们通过两层嵌套循环输出原始矩阵及其每行的最大值。

相关推荐
jieyucx6 小时前
Go语言深度解剖:Map扩容机制全解析(增量扩容+等量扩容+渐进式迁移)
开发语言·后端·golang·map·扩容策略
凉茶钱6 小时前
【c语言】动态内存管理:malloc,calloc,realloc,柔性数组
c语言·c++·vscode·柔性数组
脏脏a6 小时前
【C++模版】泛型编程:代码复用的终极利器
开发语言·c++·c++模版
island13146 小时前
【C++仿Muduo库#3】Server 服务器模块实现上
服务器·开发语言·c++
散峰而望6 小时前
【算法竞赛】C/C++ 的输入输出你真的玩会了吗?
c语言·开发语言·数据结构·c++·算法·github
小龙报6 小时前
【C语言】内存里的 “数字变形记”:整数三码、大小端与浮点数存储真相
c语言·开发语言·c++·创业创新·学习方法·visual studio
yaki_ya6 小时前
yaki-C语言:从概念基础到内存解析---数组(array)完全指南
java·c语言·算法
深耕AI6 小时前
【VS Code避坑指南】点击Python图标提示“没有Python环境”,选择安装uv后这堆输出到底是什么意思?
开发语言·python·uv
刃神太酷啦6 小时前
扒透 STL 底层!map/set 如何封装红黑树?迭代器逻辑 + 键值限制全手撕----《Hello C++ Wrold!》(23)--(C/C++)
java·c语言·javascript·数据结构·c++·算法·leetcode
星辰徐哥6 小时前
C语言网络编程:TCP、UDP、HTTP深度解析
c语言·网络·tcp/ip