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

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

题目

链接

https://leetcode-cn.com/problems/fan-zhuan-dan-ci-shun-xu-lcof/

问题描述

输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. ",则输出"student. a am I"。

示例

输入: "the sky is blue"
输出: "blue is sky the"

提示

无空格字符构成一个单词。
输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。

思路

双指针法,首先都在右侧,向左找到空格或者到头为结束,在新的字符串中添加这两个指针中间的字符,之后找到下一个单词的右侧。

复杂度分析

时间复杂度 O(n)
空间复杂度 O(n)

代码

Java

    public String reverseWords(String s) {
        s = s.trim();
        int right = s.length() - 1;
        int left = right;
        StringBuffer str = new StringBuffer();
        while (left >= 0) {
            while (left >= 0 && s.charAt(left) != ' ') {
                left--;
            }
            str.append(s.substring(left + 1, right + 1) + " ");
            while (left >= 0 && s.charAt(left) == ' ') {
                left--;
            }
            right = left;
        }
        return str.toString().trim();
    }
posted @ 2020-03-05 15:43  cheng102e  阅读(89)  评论(0编辑  收藏  举报