Leetcode 151:Reverse Words in a String

Given an input string, reverse the string word by word.

For example,
Given s = "the sky is blue",
return "blue is sky the".

Update (2015-02-12):
For C programmers: Try to solve it in-place in O(1) space

分析:

对一个字符串中得单词进行翻转,首先必须从字符串中分解出单词,然后将每个词压入堆栈,再依次弹出即可。


代码如下,运行时间约39ms:


class Solution {
public:
void reverseWords(string &s) {
		string result;
		int j = 0;
		stack<string> str_stack;
		const char* pHead = s.c_str();
		bool wordStart = false;
		const char* pStr, *pBegin, *pEnd;
		for (pStr=pHead; *pStr!='\0'; pStr++)
		{
<span style="white-space: pre;">			</span>if (!isspace(*pStr) && wordStart==false)
			{
				wordStart = true;
				pBegin = pStr;
				continue;
			}
			if (isspace(*pStr) && wordStart == true)
			{
				wordStart = false;
				pEnd = pStr;
				str_stack.push(s.substr(pBegin-pHead, pEnd-pBegin));
			}
		}
		if (wordStart == true)
		{
			wordStart = false;
			pEnd = pStr;
			str_stack.push(s.substr(pBegin-pHead, pEnd-pBegin));
		}
		s.clear();
		if (str_stack.size() > 0)
		{
			
			char space = ' ';
			while (!str_stack.empty())
			{
				string stmp = str_stack.top();
				str_stack.pop();
			if (s.length() != 0)
				{
					s.push_back(space);
				}
				s = s + stmp;
			}
		}


	}
};


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值