-cfyjbjonn
2019-01-04 22:19
采纳率: 25%
浏览 3.2k

c语言简单题,求矩阵的转置矩阵

图片说明

我的答案:

#include <stdio.h>
#define N 10

void Transpose(int (*a)[N], int n);
void  Swap(int *x, int *y);
void InputMatrix(int (*a)[N], int n);
void PrintMatrix(int (*a)[N], int n);

void InputMatrix(int (*a)[N], int n)
{
    int i,j;
    for(i = 0;i < n ;i++)
    {
        for(j = 0;j < n; j++)
        {
            scanf("%d",&a[i*n + j]);
        }

    }
}
void Transpose(int (*a)[N], int n)
{
    int i,j;
    for(i = 0;i < n ;i++)
    {
        for(j = 0;j < n; j++)
        {
            Swap(&a[i*n + j], &a[j*n + i]);
        }
    }
}

void Swap(int *x, int *y)
{
    int temp;
    temp = *x;
    *x = *y;
    *y = temp;
}

PrintMatrix(int (*a)[N], int n)
{
    int i,j;
    for(i = 0;i < n ;i++)
    {
        for(j = 0;j < n ; j++)
        {
            printf("%d\t", *a[i*n + j]);
        }
        printf("\n");
    }
}

int main()
{
    int n,s[N][N];
    printf("Input n:");
    scanf("%d",&n);
    printf("Input %d*%d matrix:\n",n,n);
    InputMatrix( s, n);
    Transpose( s, n);
    printf("The transposed matrix is:\n");
    PrintMatrix( s, n);
    return 0;

}

请问哪里错了?该怎么改?

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

3条回答 默认 最新

  • 追天荧火 2019-01-04 23:55
    最佳回答

    把 Transpose这个函数改为

    void Transpose(int(*a)[N], int n)
    {
        int i, j;
        for (i = 0; i < n; i++)
        {
            for (j = i+1; j < n; j++)  //第二部分这里的循环开始应该变为i,应该是上三角和下三角换,你之前写的就是换了一遍又换回来了,所以无效
            {
                Swap(a[i*n+j], a[j*n+i]); //本来就是指针,没有必要加&
            }
        }
    }
    

    还有PrintMaxtrix函数前 没加void

    评论
    解决 无用
    打赏 举报
查看更多回答(2条)

相关推荐 更多相似问题