【C语言习题】5.矩阵转置

文章目录


1.描述

KiKi有一个矩阵,他想知道转置后的矩阵(将矩阵的行列互换得到的新矩阵称为转置矩阵),请编程帮他解答。

输入描述:

第一行包含两个整数n和m,表示一个矩阵包含n行m列,用空格分隔。 (1≤n≤10,1≤m≤10)

从2到n+1行,每行输入m个整数(范围-231~231-1),用空格分隔,共输入n*m个数,表示第一个矩阵中的元素。

输出描述:

输出m行n列,为矩阵转置后的结果。每个数后面有一个空格。

示例图:

2.解题思路

一谈到这种矩阵,我们就可以用数组来尝试。

(1≤n≤10,1≤m≤10),根据这个条件我们可以创建一个 arr[10][10]数组

输入的n*m个数,我们可以用n,m代表行号和列号。

这个转置也很简单,直接把数组下标的行号和列号反过来就可以了。

3.具体代码

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

int main() {
    int n = 0;
    int m = 0;
    int arr[10][10] = { 0 };
    scanf("%d %d", &n, &m);
    int i = 0;
    int j = 0;
    for (i = 0; i < n; i++) {
        for (j = 0; j < m; j++) {
            scanf("%d", &arr[i][j]);
        }
    }
    for (i = 0; i < m; i++) {
        for (j = 0; j < n; j++) {
            printf("%d ", arr[j][i]);
        }
        printf("\n");
    }

    return 0;
}

4.代码讲解

  1. nm是输入的行号和列号,先初始化为0,然后定义arr数组来存放输入的数据,同时限定(1≤n≤10,1≤m≤10)
  2. 输入nm的值
  3. 定义ij,作为数组下标,然后先通过两层嵌套的for循环来完成输入工作
  4. 然后通过两层嵌套的for循环来打印转置后的矩阵,并换行。
    为数组下标,然后先通过两层嵌套的for循环来完成输入工作
  5. 然后通过两层嵌套的for循环来打印转置后的矩阵,并换行。
相关推荐
JieE21210 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言