码迷,mamicode.com
首页 > 其他好文 > 详细

Lintcode53 Reverse Words in a String solution 题解

时间:2017-08-15 23:00:52      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:题解   lintcode   

【题目描述】

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

给定一个字符串,逐个翻转字符串中的每个单词。

【题目链接】

http://www.lintcode.com/en/problem/reverse-words-in-a-string/

【题目解析】

这道题让我们翻转字符串中的单词,题目中给了我们写特别说明,如果单词之间遇到多个空格,只能返回一个,而且首尾不能有单词,并且对C语言程序员要求空间复杂度为O(1),所以我们只能对原字符串s之间做修改,而不能声明新的字符串。那么我们如何翻转字符串中的单词呢,我们的做法是,先整个字符串整体翻转一次,然后再分别翻转每一个单词(或者先分别翻转每一个单词,然后再整个字符串整体翻转一次),此时就能得到我们需要的结果了。那么这里我们需要定义一些变量来辅助我们解题,storeIndex表示当前存储到的位置,n为字符串的长度。我们先给整个字符串反转一下,然后我们开始循环,遇到空格直接跳过,如果是非空格字符,我们此时看storeIndex是否为0,为0的话表示第一个单词,不用增加空格;如果不为0,说明不是第一个单词,需要在单词中间加一个空格,然后我们要找到下一个单词的结束位置我们用一个while循环来找下一个为空格的位置,在此过程中继续覆盖原字符串,找到结束位置了,下面就来翻转这个单词,然后更新i为结尾位置,最后遍历结束,我们剪裁原字符串到storeIndex位置,就可以得到我们需要的结果

【参考答案】

www.jiuzhang.com/solutions/reverse-words-in-a-string/

Lintcode53 Reverse Words in a String solution 题解

标签:题解   lintcode   

原文地址:http://12902480.blog.51cto.com/12892480/1956494

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!