自律+奋斗=成功 2022-11-22 19:33 采纳率: 87.5%
浏览 6
已结题

n行n列矩阵转置,我这样哪里错了?


#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;
}
  • 写回答

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;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月30日
  • 已采纳回答 11月22日
  • 创建了问题 11月22日

悬赏问题

  • ¥15 关于#MATLAB#的问题,如何解决?(相关搜索:信噪比,系统容量)
  • ¥500 52810做蓝牙接受端
  • ¥15 基于PLC的三轴机械手程序
  • ¥15 多址通信方式的抗噪声性能和系统容量对比
  • ¥15 winform的chart曲线生成时有凸起
  • ¥15 msix packaging tool打包问题
  • ¥15 finalshell节点的搭建代码和那个端口代码教程
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作