设计一个函数,要用到void reverse(int a[ ],int n) 颠倒数组a的前n个元素的顺序

麻烦用VC++的,VC的就不要再粘贴过来了... 麻烦用VC++的,VC的就不要再粘贴过来了 展开
 我来答
sun_siliang
推荐于2017-09-10 · TA获得超过2.6万个赞
知道大有可为答主
回答量:9913
采纳率:100%
帮助的人:4644万
展开全部
#include<iostream>
using namespace std;
void reverse(int *a,int n)
{
int i,t;
for(i=0;i<n/2;i++)
{
t=*(a+i);
*(a+i)=*(a+n-i-1);
*(a+n-i-1)=t;
}
}
int main()
{
int i,a[]={0,1,2,3,4,5,6,7,8,9};
reverse(a,10);
for(i=0;i<10;i++)
cout<<a[i]<<' ';
cout<<endl;
return 0;
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
芝士芯片
2011-06-02 · TA获得超过190个赞
知道小有建树答主
回答量:163
采纳率:0%
帮助的人:167万
展开全部
#include <iostream>
using namespace std;
void reverse(int a[ ], int n)
{
unsigned int i = 0;
unsigned int mid = 0;
unsigned int endvalue = n;
if (n & 0x1 == 0)
{
mid = n >> 1;
}
else
mid =(n >> 1) + 1;;
for (i=0; i<mid && i < endvalue; ++i)
{
a[i] = a[i] ^ a[endvalue];
a[endvalue] = a[endvalue] ^ a[i];
a[i] = a[i] ^ a[endvalue];
--endvalue;
}
}

int main()
{
int arr[] = {0,1,2,3,4,5,6,7,8,9};
reverse(arr,5);
for (unsigned int i=0; i<sizeof(arr) / sizeof(int); ++i)
{
cout << arr[i] << '\n';
}
system("pause");
return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Gerald_Bond
2011-06-02 · TA获得超过1003个赞
知道小有建树答主
回答量:590
采纳率:0%
帮助的人:607万
展开全部
int i,x;
for(i=0;i<n/2;i++) {x=a[i];a[i]=a[n-i];a[n-i]=x;}

话说,VC++和VC在这里有区别么。。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式