矩阵基本操作算法

题目描述:

复制代码
题目描述
根据主函数和头文件提示,编写子函数

void matrixInput(int (*mat)[COL]);
void matrixPrint(int *mat[ROW]);
void matrixAddT(int *mat);
​
分别实现矩阵的输入,输出,与自身的转置相加:

void matrixInput(int (*mat)[COL]);: 输入int类型的矩阵元素,用方阵mat存储;
void matrixPrint(int *mat[ROW]); :输出方阵mat中的各个元素;
void matrixAddT(int *mat); :计算方阵mat与自身转置的和,结果存储在mat中。
Hint:请注意三个子函数的传入参数类型各不相同。

输入格式
输入一个三行三列的方阵 A,每个元素均为 int 类型。

输出格式
输出一个三行三列的方阵 B,每个元素均为 int 类型,B=A+A 
T
 。

输入样例1
1 2 3
4 5 6
7 8 9
​
输出样例1
2 6 10 
6 10 14 
10 14 18 
​
输入样例2
0 1 0
1 0 0
0 0 -1
​
输出样例2
0 2 0 
2 0 0 
0 0 -2 
​

算法:

思路:

利用上三角遍历,实现矩阵转置相加

代码实现:
cpp 复制代码
# include<stdio.h>
# include<stdlib.h>
# include<string.h>
# include<ctype.h>
#define ROW 3
#define COL 3

void matrixInput(int (*mat)[COL]){
    for(int i=0;i<3;i++){
        for(int j=0;j<3;j++){
            //输入
            scanf("%d",&mat[i][j]);
        }
    }
}
void matrixPrint(int *mat[ROW]){    
    for(int i=0;i<3;i++){
        for(int j=0;j<3;j++){
            //打印输出
            printf("%d ",mat[i][j]);
        }
        printf("\n");
    }
}
void matrixAddT(int *mat){
    int temp;
    for(int i=0;i<3;i++){
        for(int j=i;j<3;j++){//遍历上三角
            if(i==j){//对角线上的加自身
                *(mat+i*3+j)+=*(mat+i*3+j);
            }
            else{
                temp=*(mat+i*3+j);//记录原值
                *(mat+i*3+j)+=*(mat+j*3+i);//上边的要加下边
                *(mat+j*3+i)+=temp;//下边要加上边的
            }
        }
    }
}
相关推荐
快手技术2 小时前
快手提出端到端生成式搜索框架 OneSearch,让搜索“一步到位”!
算法
CoovallyAIHub21 小时前
中科大DSAI Lab团队多篇论文入选ICCV 2025,推动三维视觉与泛化感知技术突破
深度学习·算法·计算机视觉
NAGNIP1 天前
Serverless 架构下的大模型框架落地实践
算法·架构
moonlifesudo1 天前
半开区间和开区间的两个二分模版
算法
moonlifesudo1 天前
300:最长递增子序列
算法
CoovallyAIHub1 天前
港大&字节重磅发布DanceGRPO:突破视觉生成RLHF瓶颈,多项任务性能提升超180%!
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
英伟达ViPE重磅发布!解决3D感知难题,SLAM+深度学习完美融合(附带数据集下载地址)
深度学习·算法·计算机视觉
聚客AI2 天前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v2 天前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工2 天前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法