LeetCode | 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".

首先把句子看做由词组成的,例如“A B C”,因此可以将句子的所有字符前后交换,得到“C' B' A'"。显然X‘表示逆序的词X,所以第二步是将每个词中的字符串前后交换。整个过程的时间复杂度为O(n),空间复杂度为O(1)。这种方法的缺点是没有考虑许多特殊情况,例如字符串中有连续的空格,字符串开始结尾处有空格等。

代码如下:

#include<iostream>
#include<string>
using namespace std;

class Solution{
public:
	void reverseWords(string &s)
	{
		int start=0;
		int end=0;

		while(end<s.size())
		{
			if(s[end]==' ')
			{
				swapString(s,start,end-1);
				start=end+1;
				end=start;
			}
			else
				end++;
		}
		swapString(s,start,end-1);

		swapString(s,0,s.size()-1);
	}

	void swapString(string &s, int start, int end)
	{  
        while(end>start)
		{  
            char c=s[start];  
            s[start]=s[end];  
            s[end]=c;  
            start++;  
            end--;  
        }  
    }  
};


int main()
{
	string str="I am a student";
	Solution Solu;
	Solu.reverseWords(str);
	cout<<str<<endl;
	system("pause");
	return 0;
}
输出结果:



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值