c语言:二维数组行列互换

有一个mxn的二维数组a,将它所有的元素的行和列坐标互换后,存到一个nxm的数组b中。如

输入一个mxn的二维数组a,输出一个nxm的数组b。注意,最后一行输出后,不要换行。

输入数据样式:
2 3
1 2 3
4 5 6

输出数据样式:
1 4
2 5
3 6

由于行、列不确定,所以要动态处理。举例代码如下:

//#include "stdafx.h"//If the vc++6.0, with this line.
#include "stdio.h"
#include "stdlib.h"
int main(void){
    int **a,**b,m,n,i,j;
    while(1){//保证输入的行、列数为正数
        printf("Please enter m & n(int m>0,n>0)...\n");
        if(scanf("%d%d",&m,&n),m>0 && n>0)
            break;
        printf("Error, redo: ");
    }
    a=(int **)malloc((j=sizeof(int))*m);
    b=(int **)malloc(j*n);
    if(a==NULL || b==NULL){
        printf("Application memory failure...\n");
        exit(0);
    }
    for(i=0;i<m;i++)
        if((a[i]=(int *)malloc(j*n))==NULL){
            printf("Failed to create the array...\n");
            exit(0);
        }
for(i=0;i<n;i++)
    if((b[i]=(int *)malloc(j*m))==NULL){
        printf("Failed to create the array...\n");
        exit(0);
    }
    for(i=0;i<m;i++)
        for(j=0;j<n;scanf("%d",a[i]+j++));
    printf("\n");
    for(i=0;i<n;i++){
        for(j=0;j<m;j++)
            printf("%d ",b[i][j]=a[j][i]);//a的行、列互换后存入b
        printf("\n");
    }
    for(i=0;i<m;free(a[i++]));
    free(a);
    for(i=0;i<n;free(b[i++]));
    free(b);
    return 0;
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2010-11-10
你的意思是a[i][j]的数组就保存a[j][i]? 那头一个数应该不会变啊本回答被网友采纳
第2个回答  2010-11-10
只需要换二维数组下标即可,不需要借用中间数组b[][]

#include "stdio.h"
void main()
{
int **a;
int row,col;
int i,j;
printf("Please input row and col:\n");
scanf("%d%d",&row,&col);

printf("Please input data:\n");

a=(int**)malloc(row*sizeof(int));
for(i=0;i<row;i++)
a[i]=(int*)malloc(col*sizeof(int));
for(i=0;i<row;i++)
for(j=0;j<col;j++)
scanf("%d",&a[i][j]);

printf("Result:\n");

for(i=0;i<col;i++)
{
for(j=0;j<row;j++)
printf("%d ",a[j][i]);
printf("\n");
}
}

如果对你有所帮助,请记得采纳最佳答案,谢谢!
第3个回答  2010-11-13
#include<stdio.h>
main()
{
int a[20][20];
int m,n,i,j;
scanf(本回答被提问者采纳
第4个回答  2010-11-10
void zhuanhuan(int a[MAX1][],int b[MAX2][],int m,int n)
{
int i,j;
for(i=0;i<m;i++)
for(j=0;j<n;j++)
b[i][j]=a[j][i];
for(i=0;i<m;i++)
for(j=0;j<n;j++)
printf("%d ",b[i][j]);
if(i<m-1) printf("\n");
}
相似回答