数组转置

Q200.(语言: C)按如下函数原型,用二维数组作为函数参数,编程计算并输出n×n阶矩阵的转置矩阵。
其中,n由用户从键盘输入。已知n值不超过10。
void Transpose(int a[][N], int n);
void InputMatrix(int a[][N], int n);
void PrintMatrix(int a[][N], int n);
**输入提示信息要求:"Input n:\n" "Input %d*%d matrix:\n"
**输入格式:"%d"
**输出提示信息:"The transposed matrix is:\n"
**输出要求:"%d\t"
输出矩阵时,每输出一行就换行
注:不能使用指针、结构体、共用体、文件、goto、枚举类型进行编程。

对于一个m×n的矩阵A,其转置矩阵AT是一个n×m的矩阵,且AT的元素满足AT[j][i] = A[i][j],其中0 ≤ i < m,0 ≤ j < n

#include <stdio.h>

const int N = 13;

void InputMatrix(int a[][N], int n)
{
    printf("Input %d*%d matrix:\n", n, n);
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            scanf("%d", &a[i][j]);
        }
    }
}
void swap(int *a, int *b)
{
    int t = *a;
    *a = *b;
    *b = t;
}

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

void PrintMatrix(int a[][N], int n)
{
    printf("The transposed matrix is:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            printf("%d\t", a[i][j]);
        }
        printf("\n");
    }
}

int main()
{
    int n, a[N][N];
    printf("Input n:\n");
    scanf("%d", &n);
    InputMatrix(a, n);
    Transpose(a, n);
    PrintMatrix(a, n);
    return 0;
}

posted @ 2026-01-10 19:50  沫忆拾忆  阅读(4)  评论(0)    收藏  举报