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");
}
}
展开
 我来答
cools_liang
2014-04-22 · TA获得超过1385个赞
知道小有建树答主
回答量:585
采纳率:90%
帮助的人:285万
展开全部
因为是对称交换,所以循环次数只要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");
}
}
yong在路上
2014-04-22 · 超过12用户采纳过TA的回答
知道答主
回答量:20
采纳率:100%
帮助的人:27.7万
展开全部
#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;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
englishisxu
2014-04-22 · 超过23用户采纳过TA的回答
知道答主
回答量:110
采纳率:0%
帮助的人:49.4万
展开全部
/*例: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;
}

/* 希望能够帮助到你 */
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式