目录
- 题目描述
- 代码
- 补充知识
题目描述
给你一个字符串 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) 额外空间复杂度的 原地 解法。
代码
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+”); //分割一个或者多个空格