力扣151 反转字符串中的单词 Java版本

目录


题目描述

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

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

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

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

示例 1:

输入:s = "the sky is blue"

输出:"blue is sky the"

示例 2:

输入:s = " hello world "

输出:"world hello"

解释:反转后的字符串中不能存在前导空格和尾随空格。

示例 3:

输入:s = "a good example"

输出:"example good a"

解释:如果两个单词间有多余的空格,反转后的字符串需要将单词间的空格减少到仅有一个。

提示:

1 <= s.length <= 104

s 包含英文大小写字母、数字和空格 ' '

s 中 至少存在一个 单词

进阶:如果字符串在你使用的编程语言中是一种可变数据类型,请尝试使用 O(1) 额外空间复杂度的 原地 解法。

代码

java 复制代码
class Solution {
    public String reverseWords(String s) {
        if (s == null) {
            return s;
        }
        //先按照空格把字符串分成几个数组
        String[] s1 = s.split("\\s+");
        //然后交换数组中元素的顺序
        int left = 0;
        int right = s1.length - 1;
        while (left < right) {
            String temp = s1[left];
            s1[left] = s1[right];
            s1[right] = temp;
            left++;
            right--;
        }
        //再转化为字符串,各个元素之间有空格
        String res = "";

        for (int i = 0; i < s1.length; i++) {
            res = res + s1[i];
            //如果后面位置是一个单词才加空格,因为split方法按照空格拆分成数组之后,后面有可能会有一个空字符串
            if (i < (s1.length -1) && s1[i + 1] != "") {
                res = res + " ";
            }


        }
        return res;
    }
}

补充知识

split方法去除空格的四种方式

String str = "a b c d";

String[] arr1 = str.split(" "); //仅分割一个空格

String[] arr2 = str.split("s");

String[] arr3 = str.split("\t"); //空格

// 正则表达式\s表示匹配任何空白字符,+表示匹配一次或多次

String[] arr4 = str.split("\s+"); //分割一个或者多个空格

相关推荐
学习是生活的调味剂12 分钟前
nacos原理之服务注册浅析
java·开发语言·nacos·注册中心
skywalk816336 分钟前
Diffusers 库介绍,它支持LTX-2模型
python
没有bug.的程序员37 分钟前
Arthas 深度进阶:线上问题非侵入式诊断内核、方法级监控与线程阻塞排查实战指南
java·arthas·线上问题·非侵入式·方法级监控·线程阻塞
亓才孓1 小时前
[Mybatis]Mybatis框架
java·数据库·mybatis
跟Tom学编程—一对一编程辅导1 小时前
基于 Java 的 SSM 架构电子商城项目毕业设计课题选型指导文档|名企高级开发工程师全程一对一指导(含详细文档+源码+部署)
java·架构·毕业设计·课程设计
编程小风筝1 小时前
编写java代码如何写文档注释?
java·开发语言
一个处女座的程序猿O(∩_∩)O1 小时前
Python函数参数*args和**kwargs完全指南:从入门到精通
开发语言·python
与衫2 小时前
如何将SQLFlow工具产生的血缘导入到Datahub平台中
java·开发语言·数据库
m0_475064502 小时前
SpringAI-1-集成DeepSeek
java
好家伙VCC2 小时前
**发散创新:编译器优化实战——从LLVM IR到性能飞跃的奇妙旅程**
java·开发语言·python·算法