C++ 变换矩阵会导致输出错误
我想把一个4乘5的矩阵转换成一个5乘4的矩阵。这就是我到目前为止所做的: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)
#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]
解决此类问题的正确工具是调试器。在询问堆栈溢出之前,应该逐行检查代码。如需更多帮助,请阅读。至少,您应该[编辑]您的问题,以包括一个重现您的问题的示例,以及您在调试器中所做的观察主函数中的code>位于for循环内。所以你只需打印第一行,然后退出。非常感谢。你解决了我的问题。@Frank return是正确的,它位于loop的外部block@Raindrop好的,谢谢。我把它从我的帖子中删除了。当我复制粘贴代码时,它就在里面。