《剑指offer》:[42]翻转英文中单词顺序

Posted 戎·码一生

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了《剑指offer》:[42]翻转英文中单词顺序相关的知识,希望对你有一定的参考价值。

题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。

对字符串的操作,主要问题:一定要注意字符串为NULL和访问越界的情况!再就是找'\\0'.

例如输入字符串;"I love you.",经过翻转就变成:"you. love I"。看出来了吗,故意的,(不论语法)呵呵!

方案一:两次翻转法。两次翻转法就是先对整个字符串进行翻转:".uoy evol I";第二次再翻转对句子中的单个单词进行翻转:"you. love I"。这样就成功了!该方案的关键点在于实现一个字符串的翻转。
具体实现代码:
#include <iostream>
using namespace std;
char strr[]="Jenny, I love you.";
void Reverse(char *pBegin,char *pEnd)
{
	if(NULL==pBegin || NULL==pEnd)
		return;
	while(pBegin<pEnd)
	{
		char temp=*pEnd;
		*pEnd=*pBegin;
		*pBegin=temp;
		pBegin++;
		pEnd--;
	}
}
char * ReverseSentence(char *str)
{
	if(NULL==str)
		return NULL;
	char *pBegin=str;
	char *pEnd=str;
	while(*pEnd!='\\0')
		pEnd++;
	pEnd--;
	//第一步:先翻转整个句子;
	Reverse(pBegin,pEnd);
	//第二步:再翻转句子中的每个单词;
	pBegin=pEnd=str;
	while(*pBegin!='\\0')
	{
		if(*pBegin==' ')
		{
			pBegin++;
			pEnd++;
		}
		else if(*pEnd==' ' || *pEnd=='\\0')
		{
			Reverse(pBegin,--pEnd);
			pBegin=++pEnd;
		}
		else
			pEnd++;
	}
	return str;
}
int main()
{
	char *pp=NULL;
	cout<<"未翻转前:"<<strr<<endl;
	pp=ReverseSentence(strr);
	cout<<"翻转后:"<<pp<<endl;
	system("pause");
	return 0;
}

运行结果:



以上是关于《剑指offer》:[42]翻转英文中单词顺序的主要内容,如果未能解决你的问题,请参考以下文章

剑指Offer打卡day42——AcWing 77. 翻转单词顺序

剑指offer面试题42:单词翻转顺序&左右旋转字符串

Java 剑指offer(58-1) 翻转单词顺序

剑指 Offer 58 - I. 翻转单词顺序

剑指 Offer 58 - I. 翻转单词顺序

《剑指Offer——57.和为s的两个数字,58.翻转单词顺序》代码