我想知道C语言中二维数组怎么交换。

我想知道C语言中二维数组怎么交换。悬赏分:200-解决时间:2010-4-1103:18举个例子a[2][2]={1,2,3,4}我如果想把它变成a[2][2]={3,4... 我想知道C语言中二维数组怎么交换。
悬赏分:200 - 解决时间:2010-4-11 03:18
举个例子
a[2][2]={1,2,3,4}
我如果想把它变成a[2][2]={3,4,1,2}
需要这么做?
可不可以通过指针实现?
主要是可不可以用指针实现?
展开
 我来答
黄邦勇帅哥哥
2010-04-17 · TA获得超过3986个赞
知道大有可为答主
回答量:1199
采纳率:100%
帮助的人:465万
展开全部
以下程序使用指针实现,而且不只针对a[2][2]这样的数组,可以针对a[3][2],或者a[4][2]...a[n][2]或者a[n][m]这样任意数组的交换。
void main()
{
int a[2][2]={1,2,3,4};
int (*p)[2]=a;
int b;
int n=2; //行数
int m=2; //列数
for(int j=n-1,k=0;j>0;j--,k++)
for(int i=0;i<m;i++)
{b=*(p[j]+i);
*(p[j]+i)=*(p[k]+i);
*(p[k]+i)=b;

}
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
cout<<p[i][j]<<endl;

system("pause");
}
菜小超
2010-04-11 · 超过49用户采纳过TA的回答
知道答主
回答量:170
采纳率:0%
帮助的人:148万
展开全部
需要一个变量放置临时中转数据。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
skylm1234
2010-04-11 · TA获得超过306个赞
知道小有建树答主
回答量:198
采纳率:100%
帮助的人:236万
展开全部
#include<stdio.h>
void main()
{
int i,j,temp;
int a[2][2]={1,2,3,4};
for(i=0;i<2;i++)
{
for(j=0;j<2;j++)
{
printf("%d",a[i][j]);
}
printf("\n");
}
for(i=0;i<1;i++)
{
for(j=0;j<2;j++)
{
temp=a[i][j];
a[i][j]=a[i+1][j];
a[i+1][j]=temp;
}
}
for(i=0;i<2;i++)
{
for(j=0;j<2;j++)
{
printf("%d",a[i][j]);
}
printf("\n");
}
}

这个主要是按照你要求的来转换,也就是把第二行的数据跟第一行的交换,所以采取的是这种算法,其实基本思路都差不多,只要摸清楚了要实现功能的规律就好,一般用于数据交换通常要用一个中间变量来搭桥。也就是这三行
temp=a[i][j];
a[i][j]=a[i+1][j];
a[i+1][j]=temp;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
syz495683372
2010-04-11 · 超过10用户采纳过TA的回答
知道答主
回答量:15
采纳率:0%
帮助的人:0
展开全部
可以用指针实现,代码如下:
#include<stdio.h>
int main()
{
int t,a[2][2]={{1,2},{3,4}},(*p)[2],i,j;
p=a;
t=*(*(p)+0);*(*(p)+0)=*(*(p+1)+0);*(*(p+1)+0)=t;
p=a;
t=*(*(p)+1);*(*(p)+1)=*(*(p+1)+1);*(*(p+1)+1)=t;
for(i=0;i<2;i++)
{
for(j=0;j<2;j++)
{
printf("%d",a[i][j]);
}
printf("\n");
}
}
刚刚有点问题,稍微改了下。。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cmnull
2010-04-11 · TA获得超过310个赞
知道小有建树答主
回答量:102
采纳率:0%
帮助的人:143万
展开全部
当然可以用指针实现,指针是操作数组的最基本的方法

#include <iostream>

void swap(int *x, int *y)
{
int tmp;
tmp = *x;
*x = *y;
*y = tmp;
}

int main()
{
using namespace std;
int a[2][2] = {1, 2, 3, 4};
cout << a[0][0] << a[0][1] << a[1][0] << a[1][1] << endl;
int (*p)[2] = 0;
p = a;
swap(*p, *(p + 1));
swap(*p + 1, *(p + 1) + 1);
cout << a[0][0] << a[0][1] << a[1][0] << a[1][1] << endl;
return 0;
};

VS2008 编译通过
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Rocky_joy
2010-04-11 · TA获得超过466个赞
知道答主
回答量:391
采纳率:0%
帮助的人:49.9万
展开全部
这么多朋友帮助你,你快点吧,等啥呢
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式