【子串】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 是字符串的长度。
相关推荐
重庆小透明16 分钟前
力扣刷题记录【1】146.LRU缓存
java·后端·学习·算法·leetcode·缓存
lang2015092822 分钟前
Reactor操作符的共享与复用
java
TTc_32 分钟前
@Transactional事务注解的批量回滚机制
java·事务
desssq35 分钟前
力扣:70. 爬楼梯
算法·leetcode·职场和发展
clock的时钟1 小时前
暑期数据结构第一天
数据结构·算法
wei_shuo1 小时前
飞算 JavaAI 开发助手:深度学习驱动下的 Java 全链路智能开发新范式
java·开发语言·飞算javaai
小小小小王王王2 小时前
求猪肉价格最大值
数据结构·c++·算法
欧阳秦穆2 小时前
apoc-5.24.0-extended.jar 和 apoc-4.4.0.36-all.jar 啥区别
java·jar
岁忧2 小时前
(LeetCode 面试经典 150 题 ) 58. 最后一个单词的长度 (字符串)
java·c++·算法·leetcode·面试·go
Java初学者小白2 小时前
秋招Day14 - Redis - 应用
java·数据库·redis·缓存