//第一步反转所有的字符
//第二部挨个反转单词
#include<iostream>
#include<string.h>
using namespace std;
void Reverse(char *pbegin,char *pend) //反转字符串
{
if(pbegin==NULL && pend==NULL)
return;
while(pbegin<pend)
{
char ind = *pend;
*pend = *pbegin;
*pbegin = ind;
pend--;
pbegin++;
}
}
void reversesentence(char *a)
{
if(a==NULL)
return;
char *pbegin = a;
char *pend = a;
while(*pend!='\0')
pend++;
pend--;
Reverse(pbegin,pend); //反转整个句子
pbegin = pend = a;
while(*pbegin!='\0') //反转单词
{
if(*pend == '\0'||*pend == ' ')
{
Reverse(pbegin,pend-1);
pend++;
pbegin = pend;
}
else
pend++;
}
}
int main()
{
char a[]="I am a student.";
reversesentence(a);
cout<<a;
return 0;
}
反转单词顺序
最新推荐文章于 2023-09-17 11:10:53 发布