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

有一个mxn的二维数组a,将它所有的元素的行和列坐标互换后,存到一个nxm的数组b中。如输入一个mxn的二维数组a,输出一个nxm的数组b。注意,最后一行输出后,不要换行... 有一个mxn的二维数组a,将它所有的元素的行和列坐标互换后,存到一个nxm的数组b中。如

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

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

输出数据样式:
1 4
2 5
3 6
展开
 我来答
White_MouseYBZ
2015-10-19 · TA获得超过4万个赞
知道大有可为答主
回答量:2.1万
采纳率:82%
帮助的人:6658万
展开全部

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

//#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;
}
菜鸟级程序员
2010-11-10 · TA获得超过342个赞
知道小有建树答主
回答量:213
采纳率:0%
帮助的人:161万
展开全部
你的意思是a[i][j]的数组就保存a[j][i]? 那头一个数应该不会变啊
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
鷹弈
2010-11-10 · TA获得超过5194个赞
知道大有可为答主
回答量:1257
采纳率:0%
帮助的人:624万
展开全部
只需要换二维数组下标即可,不需要借用中间数组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");
}
}

如果对你有所帮助,请记得采纳最佳答案,谢谢!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
2010KK2010
2010-11-13 · TA获得超过386个赞
知道答主
回答量:138
采纳率:0%
帮助的人:153万
展开全部
#include<stdio.h>
main()
{
int a[20][20];
int m,n,i,j;
scanf(
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
时红垒
2010-11-10
知道答主
回答量:11
采纳率:0%
帮助的人:9.2万
展开全部
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");
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式