化工企业建网站,怎样做网站镜像,兴仁企业建站公司,服务公司取名最好的名字题目描述#xff1a;
题目描述
根据主函数和头文件提示#xff0c;编写子函数void matrixInput(int (*mat)[COL]);
void matrixPrint(int *mat[ROW]);
void matrixAddT(int *mat);
分别实现矩阵的输入#xff0c;输出#xff0c;与自身的转置相加#xff1a;void matr…题目描述
题目描述
根据主函数和头文件提示编写子函数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 类型BAA
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
算法
思路
利用上三角遍历实现矩阵转置相加
代码实现
# includestdio.h
# includestdlib.h
# includestring.h
# includectype.h
#define ROW 3
#define COL 3void matrixInput(int (*mat)[COL]){for(int i0;i3;i){for(int j0;j3;j){//输入scanf(%d,mat[i][j]);}}
}
void matrixPrint(int *mat[ROW]){ for(int i0;i3;i){for(int j0;j3;j){//打印输出printf(%d ,mat[i][j]);}printf(\n);}
}
void matrixAddT(int *mat){int temp;for(int i0;i3;i){for(int ji;j3;j){//遍历上三角if(ij){//对角线上的加自身*(mati*3j)*(mati*3j);}else{temp*(mati*3j);//记录原值*(mati*3j)*(matj*3i);//上边的要加下边*(matj*3i)temp;//下边要加上边的}}}
}