2016-09-24 79 views
-3

我正在尝试将4乘5矩阵转置为5乘4矩阵。这是我迄今所做的:转置矩阵会导致错误的输出

#include <stdio.h> 

void transposeMatrix(int A2[4][5],int A1[5][4]) 
{ 
    int i, j; 

    for (i = 0; i < 5; ++i){ 
     for (j = 0; j < 4; ++j) 
      A1[j][i]=A2[i][j]; 
    } 
} 

int main(void) 
{ 
    int A2[4][5] = { 
     { 7, 4, 2, 1, 12 }, 
     { 4, 6, 22, 11, 6 }, 
     { 12, 10, 3, 1, 2 }, 
     { 20, 4, 1, 3, 4 }, 
    }; 
    int A1[5][4]; 
    int i, j; 

    printf("Original matrix:\n "); 
    for (i = 0; i < 4; ++i){ 
     for (j = 0; j < 5; ++j) 
      printf("%5i", A2[i][j]); 
     printf("\n"); 
    } 

    printf("Transposed matrix:\n"); 
    transposeMatrix(A2, A1); 
    for (i = 0; i < 5; ++i){ 
     for (j = 0; j < 4; ++j) 
      printf("%5i", A1[i][j]); 
     printf("\n"); 
    } 
    return 0; 
} 

当我运行我的代码,这是我得到:

 
Original matrix: 
    7 4 2 1 12 
    4 6 22 11 6 
    12 10 3 1 2 
    20 4 1 3 4 
Transposed matrix: 
    7 4 12 20 
-858993460 6 10 4 
998952744 22 3 1 
11599080 11 1 3 
10495049-858993460-858993460-858993460 

它看起来像只调换的第一行。我究竟做错了什么?

+1

解决此类问题的正确工具是您的调试器。在*堆栈溢出问题之前,您应该逐行执行您的代码。如需更多帮助,请阅读[如何调试小程序(由Eric Lippert撰写)](https://ericlippert.com/2014/03/05/how-to-debug-small-programs/)。至少,您应该\编辑您的问题,以包含一个[最小,完整和可验证](http://stackoverflow.com/help/mcve)示例,该示例再现了您的问题,以及您在调试器。 –

+0

主函数中的'return 0;'在for循环中。所以你只需打印第一行然后退出。 – Franck

回答

0

您的代码中有一个错误。

这是transpose函数中的索引问题。

for (i = 0; i < 5; ++i){ 
    for (j = 0; j < 4; ++j) 
     A1[i][j]=A2[j][i]; 
} 

而不是A1[j][i]=A2[i][j]

+0

非常感谢。你解决了我的问题。 – Newbiehere

+0

@Frank return是正确的,它在循环的块外面 – Raindrop7

+0

@Raindrop好吧,谢谢我从我的帖子中删除它。当我复制代码时,它在里面。 – Franck