题目:
翻转句子中单词的顺序。
题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。
句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。
原句子交换后变成.tneduts a ma I,现在需要翻转每个以空格分开的单词,即可
翻转句子中单词的顺序。
题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。
句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。
例如输入“I am a student.”,则输出“student. a am I”。
先考虑如果没有空格时候,如果反转一个单词,直接从后往前交换即可
void Reverse(char* pBegin,char* pEnd)
{
if(pBegin == NULL || pEnd == NULL)
return;
while (pBegin<pEnd)
{
char temp = *pBegin;
*pBegin = *pEnd;
*pEnd = temp;
pBegin++;
pEnd--;
}
}
原句子交换后变成.tneduts a ma I,现在需要翻转每个以空格分开的单词,即可
char* ReverseSentence(char* pData)
{
if(pData==NULL) return NULL;
char* pBegin = pData;
char* pEnd = pData;
while (*pEnd!='\0')
pEnd++;
pEnd--;
Reverse(pBegin,pEnd);
pBegin = pEnd = pData;
while (*pBegin != '\0')
{
if(*pBegin == ' ')
{
pBegin++;
pEnd++;
}
else if(*pEnd == ' '||*pEnd=='\0')
{
Reverse(pBegin,--pEnd);
pBegin = ++pEnd;
}
else
{
pEnd++;
}
}
return pData;
}