算法-转置矩阵
程序员文章站
2022-03-15 20:25:02
...
输入两个整数m和n,再输入m*n个数存入m行n列数组中,将该数组地转置矩阵n*m输出
#include <stdio.h>
void main()
{
int i,j,m,n,**a;
scanf("%d %d",&m,&n);
a=(int **)malloc(sizeof(int *)*m);
for(i=0;i<m;i++)
a[i]=(int *)malloc(sizeof(int)*n);
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
printf("%d ",a[j][i]);
printf("\n");
}
}
这是在动态分配数组空间地基础上实现的,我以前记得c定义数组不能使用变量,但是刚才试了试可以,如果使用变量,main函数内前五行改为以下:
int i,j,m,n;
scanf("%d %d",&m,&n);
int a[m][n];
可能是编译器或者别的原因吧,malloc两个**我一直不太会,这是一个大佬教的,哈哈!
下一篇: 【算法题】【★】移除元素