今天在做15PB练习题目的时候,提高题目如下要求,思考了一下这个问题,在网上向前辈们学习了一下,其中比较喜欢的一种解决方法如下:
最多定义一个变量实现字符串反转函数
代码来自于讨论结果之一http://bbs.csdn.net/topics/80194408
#include <iostream> //包括流的输入输出库
using namespace std;//使用std命名空间
void revers(char *s)
{
char *p;
if(!s)return;
for(p=s;*p;p++);
--p;
while (p>s)
{
*p ^= *s ^= *p ^=*s;//通过异或运算不使用第三个变量,直接交换两个变量
--p;
++s;
}
}
int main()
{
char p[]="Zheng de hao xiang ni,wo zai ye li hu huan zhe ni";
revers(p);
std::cout<<p<<endl;
revers(p);
cout<<p<<endl;
return 0;
}