C++ 变换矩阵会导致输出错误

C++ 变换矩阵会导致输出错误,c++,matrix,visual-studio-2013,transpose,C++,Matrix,Visual Studio 2013,Transpose,我想把一个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)

我想把一个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;
}
#包括
无效转置矩阵(int A2[4][5],int A1[5][4])
{
int i,j;
对于(i=0;i<5;++i){
对于(j=0;j<4;++j)
A1[j][i]=A2[i][j];
}
}
内部主(空)
{
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(“原始矩阵:\n”);
对于(i=0;i<4;++i){
对于(j=0;j<5;++j)
printf(“%5i”,A2[i][j]);
printf(“\n”);
}
printf(“转置矩阵:\n”);
转置矩阵(A2,A1);
对于(i=0;i<5;++i){
对于(j=0;j<4;++j)
printf(“%5i”,A1[i][j]);
printf(“\n”);
}
返回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 原始矩阵: 7 4 2 1 12 4 6 22 11 6 12 10 3 1 2 20 4 1 3 4 转置矩阵: 7 4 12 20 -858993460 6 10 4 998952744 22 3 1 11599080 11 1 3 10495049-858993460-858993460-858993460
看起来它只转置了第一行。我做错了什么?

您的代码中有一个错误

这是
转置
函数中的索引问题

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

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

解决此类问题的正确工具是调试器。在询问堆栈溢出之前,应该逐行检查代码。如需更多帮助,请阅读。至少,您应该[编辑]您的问题,以包括一个重现您的问题的示例,以及您在调试器中所做的观察位于for循环内。所以你只需打印第一行,然后退出。非常感谢。你解决了我的问题。@Frank return是正确的,它位于loop的外部block@Raindrop好的,谢谢。我把它从我的帖子中删除了。当我复制粘贴代码时,它就在里面。