【子串】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 是字符串的长度。
相关推荐
秋意钟5 分钟前
Spring新版本
java·后端·spring
椰椰椰耶7 分钟前
【文档搜索引擎】缓冲区优化和索引模块小结
java·spring·搜索引擎
mubeibeinv8 分钟前
项目搭建+图片(添加+图片)
java·服务器·前端
青莳吖9 分钟前
Java通过Map实现与SQL中的group by相同的逻辑
java·开发语言·sql
Buleall17 分钟前
期末考学C
java·开发语言
重生之绝世牛码19 分钟前
Java设计模式 —— 【结构型模式】外观模式详解
java·大数据·开发语言·设计模式·设计原则·外观模式
小蜗牛慢慢爬行25 分钟前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
荒古前31 分钟前
龟兔赛跑 PTA
c语言·算法
Colinnian34 分钟前
Codeforces Round 994 (Div. 2)-D题
算法·动态规划