栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

21-矩阵转置

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

21-矩阵转置

题目

利用数组解决线性代数中的矩阵转置问题。
设有一矩阵为m×n阶即m行n列),第i行j列的元素是a(i,j),需要将该矩阵转置为n×m阶的矩阵,使其中元素满足 b(j,i)=a(i,j)。

思路:

没啥好说的

代码:
#include 
#include 


#define N 100
int a[N][N];
int b[N][N];

void transpose(int a[N][N], int b[N][N], int m, int n) {
    int i = 0;
    int j = 0;
    for (i = 0; i < m; i++) {
        for (j = 0; j < n; j++) {
            b[j][i] = a[i][j];
        }
    }
}

void show(int a[N][N], int m, int n) {
    int i = 0;
    int j = 0;
    for (i = 0; i < m; i++) {
        for (j = 0; j < n; j++) {
            printf("%d", a[i][j]);
            if (j != n - 1) {
                printf(" ");
            }
        }
        printf("n");
    }
}

int main() {
    int m = 0, n = 0;
    printf("please input the matrix's row and column:n");
    scanf("%d%d", &m, &n);
    int i = 0;
    int j = 0;
    printf("please input the element of matrix:n");
    for (i = 0; i < m; i++) {
        for (j = 0; j < n; j++) {
            scanf("%d", &a[i][j]);
        }
    }
    show(a, m, n);
    transpose(a, b, m, n);
    show(b, n, m);
    return 0;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/588085.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号