c语言二维数组行交换
例:12345678910111213141516改为16151413121110987654321#definem4#definen4#include<stdio.h>...
例:1 2 3 4
5 6 7 8
9 10 11 12
13 14 15 16
改为
16 15 14 13
12 11 10 9
8 7 6 5
4 3 2 1
#define m 4
#define n 4
#include<stdio.h>
void main()
{
int a[m][n];
int i,j,temp;
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
temp=a[i][j];
a[i][j]=a[m-i-1][n-j-1];
a[m-i-1][n-j-1]=temp;
}
}
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
printf("%d",a[i][j]);
printf("\n");
}
} 展开
5 6 7 8
9 10 11 12
13 14 15 16
改为
16 15 14 13
12 11 10 9
8 7 6 5
4 3 2 1
#define m 4
#define n 4
#include<stdio.h>
void main()
{
int a[m][n];
int i,j,temp;
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
temp=a[i][j];
a[i][j]=a[m-i-1][n-j-1];
a[m-i-1][n-j-1]=temp;
}
}
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
printf("%d",a[i][j]);
printf("\n");
}
} 展开
3个回答
展开全部
因为是对称交换,所以循环次数只要n的一半就可以了,否则换过去的,又会换回来了
改为
#define m 4
#define n 4
#include<stdio.h>
void main()
{
int a[m][n];
int i,j,temp;
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
for(i=0;i<m;i++)
{
for(j=0;j<n/2;j++)
{
temp=a[i][j];
a[i][j]=a[m-i-1][n-j-1];
a[m-i-1][n-j-1]=temp;
}
}
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
printf("%5d",a[i][j]);
printf("\n");
}
}
改为
#define m 4
#define n 4
#include<stdio.h>
void main()
{
int a[m][n];
int i,j,temp;
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
for(i=0;i<m;i++)
{
for(j=0;j<n/2;j++)
{
temp=a[i][j];
a[i][j]=a[m-i-1][n-j-1];
a[m-i-1][n-j-1]=temp;
}
}
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
printf("%5d",a[i][j]);
printf("\n");
}
}
展开全部
#define m 4
#define n 4
#include<stdio.h>
int main()
{
int a[m][n];
int i,j,temp;
for(i=0;i<m;i++)
for(j=0;j<n;j++)
scanf("%d",&a[i][j]);
//m 取 m/2
for(i=0;i<m/2;i++)
{
// n取 n/2
for(j=0;j<n/2;j++)
{
temp=a[i][j];
a[i][j]=a[m-i-1][n-j-1];
a[m-i-1][n-j-1]=temp;
}
}
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
printf("%d\t",a[i][j]);
printf("\n");
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
/*例:1 2 3 4
5 6 7 8
9 10 11 12
13 14 15 16
改为
16 15 14 13
12 11 10 9
8 7 6 5
4 3 2 1
*/
#define m 4
#define n 4
#include<stdio.h>
int main(int argc, char *argv[])
{
int a[m][n];
int i, j, temp;
for(i=0; i<m; i++)
{
for(j=0; j<n; j++)
{
scanf("%d", &a[i][j]);
}
}
printf("原矩阵为:\n");
for(i=0; i<m; i++)
{
for(j=0; j<n; j++)
{
printf("%d\t", a[i][j]);
}
printf("\n");
}
for(i=0; i<m/2; i++)
{
for(j=0; j<n/2; j++)
{
temp = a[i][j];
a[i][j] = a[m-i-1][n-j-1];
a[m-i-1][n-j-1]=temp;
}
}
printf("变换后矩阵为:\n");
for(i=0; i<m; i++)
{
for(j=0; j<n; j++)
{
printf("%d\t",a[i][j]);
}
printf("\n");
}
return 0;
}
/* 希望能够帮助到你 */
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询