`

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.

Clarification:
  • What constitutes a word?
    A sequence of non-space characters constitutes a word.
  • Could the input string contain leading or trailing spaces?
    Yes. However, your reversed string should not contain leading or trailing spaces.
  • How about multiple spaces between two words?
    Reduce them to a single space in the reversed string.

Solution 1: two-pass.

public String reverseWords(String s) {
    String[] words = s.trim().split("\\s+");
	if(words.length == 0) {
        return "";
    }
	StringBuilder sb = new StringBuilder(words[words.length-1]);
	for(int i=words.length-2; i >=0; i--) {
		sb.append(" "+words[i]);
	}
	return sb.toString();
}

 

Solution 2: one-pass.

We can do better in one-pass. While iterating the string in reverse order, we keep track of a word’s begin and end position. When we are at the beginning of a word, we append it.

public String reverseWords(String s) {
    StringBuilder sb = new StringBuilder();
    int end = s.length();
    int i = end-1;
    while(i>=0) {
        if(s.charAt(i) == ' ') {
            if(i < end-1) {
                sb.append(s.substring(i+1, end)).append(" ");
            }
            end = i;
        }
        i--;
    }
    sb.append(s.substring(i+1, end));
    return sb.toString().trim();
}

 

重构了以下以上代码:

public String reverseWords(String s) {
    StringBuilder sb = new StringBuilder();
    int last = s.length();
    for(int i=s.length()-1; i>=-1; i--) {
        if(i==-1 || s.charAt(i)==' ') {
            String word = s.substring(i+1, last);
            if(!word.isEmpty()) {
                if(sb.length() != 0) sb.append(' ');
                sb.append(word);
            }
            last = i;
        }
    }
    return sb.toString();
}

 

Solution 3:

public String reverseWords(String s) {
    if(s == null || s.isEmpty()) return s;
    char[] data = s.toChartArray();
    int n = data.length;
    reverse(data, 0, n-1);
    
    int last = -1;
    for(int i=0; i<=n; i++) {
        if(i == n || data[i] == ' ') {
            if(i-last>1) reverse(data, last+1, i-1);
            last = i;
        }
    }
    
    return new String(data);
}

private void reverse(char[] data, int start, int end) {
    while(start < end) {
        char tmp = data[start];
        data[start++] = data[end];
        data[end--] = tmp;
    }
}

 

分享到:
评论

相关推荐

    js-leetcode题解之151-reverse-words-in-a-string.js

    javascript js_leetcode题解之151-reverse-words-in-a-string.js

    python-leetcode题解之151-Reverse-Words-in-a-String.py

    python python_leetcode题解之151_Reverse_Words_in_a_String.py

    Reverse words in a string-leetcode

    Reverse words in a string-leetcode

    python-leetcode题解之186-Reverse-Words-in-a-String-II.py

    python python_leetcode题解之186_Reverse_Words_in_a_String_II.py

    leetcode答案-leetcode:我对leetcode151的回答

    LeetCode 151题,全称为"Reverse Words in a String"(反转字符串中的单词),这是一道中等难度的题目。题目要求用户编写一个函数,接收一个只包含空格和字母的字符串作为输入,然后返回这个字符串中单词的顺序被...

    LeetCode最全代码

    421 | [Maximum XOR of Two Numbers in an Array](https://leetcode.com/problems/maximum-xor-of-two-numbers-in-an-array/) | [C++](./C++/maximum-xor-of-two-numbers-in-an-array.cpp) [Python](./Python/...

    TWDH#Leetcode-From-Zero#13.反转字符串中的单词 III1

    557. 反转字符串中的单词 IIIpublic String reverseWords(String s) {StringBuilder sb = new S

    leetcode分类-leetcode:leetcode刷题(中等难度分类)

    字符串处理题目也是LeetCode的重要部分,例如"Reverse Words in a String"(翻转字符串中的单词)和"Valid Palindrome"(验证回文串)。这些题目通常涉及到字符串的遍历、分割、比较以及特殊字符的处理。 四、位...

    leetcode338-coding_notebook:编码_笔记本

    第 338 章概括 [(雅虎)4。 两个排序数组的中位数](Leetcode 问题/数组和字符串/4.median_of_two_sorted_array.md) [(雅虎)13。...String/151.reverse_words_in_a_string.md) [167. Two Sum 2 - In

    leetcode2sumc-Leetcode-2020:刷刷Leetcode并作纪录

    leetcode 2 sum c Leetcode 练习记录 这个专案主要存放我练习Leetcode有针对难度分类的集合题库(Collection Question) 准备方式 分析tag的热门标签,熟悉各个标签解题的思路(解决该标签全部的easy和medium为主),再...

    leetcode中国-leetCodeSolution::thumbs_up:leetCode刷题项目

    reverseWords titleToNumber toLowerCase defangIPaddr replaceSpace removeOuterParentheses 复杂题目值得参考 sortString 使用字典排序 sort((a, b) =&gt; a.charCodeAt() - b.charCodeAt()) 有参考价值 Maths isPal

    leetcode-go:我使用Golang解决LeetCode问题的方法

    goMy solution to LeetCode problems using GolangProblems 题库Array 数组NoTitle题名DifficultyStatus11Container With Most Water盛最多水的容器MediumSolved26Remove Duplicates from Sorted Array删除有序数组...

    算法-leetcode-剑指offer上的题很多

    - **反转单词(Reverse Words)**: 将字符串中的单词顺序反转。 - **验证回文字符串(Valid Palindrome)**: 判断一个字符串是否是回文。 - **最长回文子串(Longest Palindromic Substring)**: 找出字符串中最长的回文...

    leetcode写题闪退-LeetCode:leetcodeOJ

    leetcode写题闪退 #*的多少代表此题的有意思程度 有几题第一次写的时候思绪比较混乱: *****Regular Expression Matching 2014.10.29 对于Find Minimum in Rotated Sorted Array II 和 Find Minimum in Rotated ...

    算法刷题笔记leetcode/lintcode

    - Reverse Words in a String(反转字符串中的单词) - Valid Palindrome(回文字符串验证) - Longest Palindromic Substring(最长回文子串) - Space Replacement(URL化) - Wildcard Matching(通配符匹配...

    Coding Interview In Java

    2 Reverse Words in a String II 19 3 Evaluate Reverse Polish Notation 21 4 Isomorphic Strings 25 5 Word Ladder 27 6 Word Ladder II 29 7 Median of Two Sorted Arrays 33 8 Kth Largest Element in an Array ...

    Leetcode book刷题必备

    7. Reverse Words in a String II:翻转字符串中的单词顺序,并且整个字符串也要翻转。 8. String to Integer (atoi):将字符串转换成整数,考虑溢出等问题。 9. Valid Number:判断一个字符串是否是有效的数字表示...

    CleanCodeHandbook_v1.0.3

    - Reverse Words in a String(字符串中的单词翻转) - String to Integer (atoi)(字符串转换整数) - Longest Substring Without Repeating Characters(无重复字符的最长子串) 4. Math(数学): 算法题目中...

    java-leetcode面试题解双指针之第151题反转字符串中的单词.zip

    public String reverseWords(String s) { if (s == null || s.isEmpty()) return s; char[] chars = s.toCharArray(); int left = 0, right = chars.length - 1; while (left ) { // 移动右指针,直到找到...

    LeetCode

    9. **字符串处理**:涉及到模式匹配、子串查找、字符串反转等(如LeetCode的"Reverse Words in a String"问题)。 10. **图论**:包括图的深度优先遍历、拓扑排序、最小生成树等(如LeetCode的"Course Schedule...

Global site tag (gtag.js) - Google Analytics