#include <stdio.h>
void move(int (*pointer)[n],int n)
{
int i,j;
int b[n][n];
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
b[j][i]=*(*(pointer+i)+j);
}
}
for(i=0;i<n;i++)
{for(j=0;j<n;j++)
printf("%d ",b[i][j]);
printf("\n");
}
printf("\n");
}
int main()
{
int i,j,t,s,m,n;
scanf("%d",&n);
int a[n][n];
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
}
int (*point)[n];
point=a;
move(point,n);
return 0;
}

n行n列矩阵转置,我这样哪里错了?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- qzjhjxj 2022-11-22 20:10关注
修改如下,供参考:
#include <stdio.h> #define N 10 void move(int (*pointer)[N],int n) { int i,j,tmp; //int b[n][n]; for(i=0;i<n;i++){ for(j=i;j<n;j++) { tmp = pointer[i][j]; pointer[i][j] = pointer[j][i]; pointer[j][i] = tmp; } //printf("%d ",b[i][j]); //printf("\n"); } //printf("\n"); } int main() { int a[N][N]; int i,j,t,s,m,n; scanf("%d",&n); for(i=0;i<n;i++) for(j=0;j<n;j++) scanf("%d",&a[i][j]); int (*point)[N]; point=a; move(point,n); for(i=0;i<n;i++){ //输出转置后的数组 for(j=0;j<n;j++) printf("%d ",a[i][j]); printf("\n"); } return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报