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 展开
输入一个mxn的二维数组a,输出一个nxm的数组b。注意,最后一行输出后,不要换行。
输入数据样式:
2 3
1 2 3
4 5 6
输出数据样式:
1 4
2 5
3 6 展开
5个回答
展开全部
由于行、列不确定,所以要动态处理。举例代码如下:
//#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;
}
展开全部
你的意思是a[i][j]的数组就保存a[j][i]? 那头一个数应该不会变啊
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
只需要换二维数组下标即可,不需要借用中间数组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");
}
}
如果对你有所帮助,请记得采纳最佳答案,谢谢!
#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");
}
}
如果对你有所帮助,请记得采纳最佳答案,谢谢!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
main()
{
int a[20][20];
int m,n,i,j;
scanf(
main()
{
int a[20][20];
int m,n,i,j;
scanf(
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
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");
}
{
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");
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询