【子串】151. 反转字符串中的单词【中等】

反转字符串中的单词

  • 给你一个字符串 s ,请你反转字符串中 单词 的顺序。

单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。

返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。

注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。

解题思路

  • 要反转字符串中的单词顺序,可以先将整个字符串进行反转,然后再逐个单词进行反转。
  • 这样就可以得到单词顺序颠倒的结果字符串。

java实现

java 复制代码
public class ReverseWords {
    public String reverseWords(String s) {
        // 去除字符串首尾空格,并将连续多个空格替换为一个空格
        //"\s" 表示空白字符,包括空格、制表符、换行符等
        //"\s+" 表示匹配一个或多个连续的空白字符
        s = s.trim().replaceAll("\\s+", " ");
        // 将字符串转换为字符数组
        char[] chars = s.toCharArray();
        // 反转整个字符串
        reverse(chars, 0, chars.length - 1);
        
        // 反转每个单词
        int start = 0;
        for (int end = 0; end < chars.length; end++) {
            if (chars[end] == ' ') {
                reverse(chars, start, end - 1);
                start = end + 1;
            }
        }
        // 反转最后一个单词
        reverse(chars, start, chars.length - 1);
        
        return new String(chars);
    }
    
    // 辅助函数:反转字符数组中指定范围的字符
    private void reverse(char[] chars, int left, int right) {
        while (left < right) {
            char temp = chars[left];
            chars[left] = chars[right];
            chars[right] = temp;
            left++;
            right--;
        }
    }

    public static void main(String[] args) {
        ReverseWords reverseWords = new ReverseWords();
        String s1 = "the sky is blue";
        System.out.println("Test Case 1:");
        System.out.println("Input: \"the sky is blue\"");
        System.out.println("Reversed Words: \"" + reverseWords.reverseWords(s1) + "\""); // Expected: "blue is sky the"

        String s2 = "  hello world  ";
        System.out.println("\nTest Case 2:");
        System.out.println("Input: \"  hello world  \"");
        System.out.println("Reversed Words: \"" + reverseWords.reverseWords(s2) + "\""); // Expected: "world hello"
    }
}

时间空间复杂度

  • 时间复杂度: 遍历字符串的时间复杂度为 O(n),其中 n 是字符串的长度。
  • 空间复杂度: 使用了额外的字符数组,空间复杂度为 O(n),其中 n 是字符串的长度。
相关推荐
花开富贵ii41 分钟前
代码随想录算法训练营四十三天|图论part01
java·数据结构·算法·深度优先·图论
weixin_307779131 小时前
AWS Lambda解压缩S3 ZIP文件流程
python·算法·云计算·aws
布朗克1682 小时前
Java 10 新特性及具体应用
java·开发语言·新特性·java10
code小毛孩2 小时前
leetcode hot100数组:缺失的第一个正数
数据结构·算法·leetcode
ZZHow10245 小时前
JavaWeb开发_Day05
java·笔记·web
CHEN5_025 小时前
【Java虚拟机】垃圾回收机制
java·开发语言·jvm
Warren985 小时前
Lua 脚本在 Redis 中的应用
java·前端·网络·vue.js·redis·junit·lua
legendary_bruce8 小时前
【22-决策树】
算法·决策树·机器学习
艾伦~耶格尔9 小时前
【数据结构进阶】
java·开发语言·数据结构·学习·面试
爪洼传承人9 小时前
18- 网络编程
java·网络编程