【子串】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 是字符串的长度。
相关推荐
我的golang之路果然有问题3 小时前
积累的 java 找工作资源
java·笔记
蜕变菜鸟3 小时前
JS的Object.keys()和sort()排序的用法
数据结构·算法
源代码•宸3 小时前
Golang基础语法(go语言error、go语言defer、go语言异常捕获、依赖管理、Go Modules命令)
开发语言·数据库·后端·算法·golang·defer·recover
编程大师哥3 小时前
Java 常见异常(按「运行时 / 编译时」分类)
java·开发语言
如果你想拥有什么先让自己配得上拥有3 小时前
算数顺序的逻辑和发展?
算法
SnrtIevg3 小时前
Vavr 用户指南
java·后端
怦怦蓝4 小时前
IDEA 开发邮件发送功能:全流程报错解决方案汇总
java·ide·intellij-idea·发邮件
Cx330❀4 小时前
【优选算法必刷100题】第43题(模拟):数青蛙
c++·算法·leetcode·面试
杜子不疼.4 小时前
【LeetCode30_滑动窗口 + 哈希表】:三招搞定“串联所有单词的子串”
数据结构·算法·哈希算法
闻缺陷则喜何志丹4 小时前
【C++动态规划 状压dp】1879. 两个数组最小的异或值之和|2145
c++·算法·动态规划·力扣·数组·最小·动态规范