151. 颠倒字符串中的单词
题目描述
给你一个字符串 s ,颠倒字符串中 单词 的顺序。
单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。
返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。
注意:输入字符串 s中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。
输入输出
1 2 3 4 5 6 7 8 9 10
| 输入:s = "the sky is blue" 输出:"blue is sky the"
输入:s = " hello world " 输出:"world hello" 解释:颠倒后的字符串中不能存在前导空格和尾随空格。
输入:s = "a good example" 输出:"example good a" 解释:如果两个单词间有多余的空格,颠倒后的字符串需要将单词间的空格减少到仅有一个。
|
基本思路
看代码注释就可理解
时复$O(n)$ 空复$O(n)$
java实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
| class Solution { public String reverseWords(String s) { StringBuilder sb = trimspace(s); reverse(sb, 0, sb.length() - 1); reverseWord(sb); return sb.toString(); }
public StringBuilder trimspace(String s){ StringBuilder sb = new StringBuilder(); int left = 0, right = s.length() - 1; while(left <= right && s.charAt(left) == ' '){ left++; } while(left <= right && s.charAt(right) == ' '){ right--; }
while(left <= right){ char c = s.charAt(left); if(c != ' '){ sb.append(c); } else if(sb.charAt(sb.length() - 1) != ' '){ sb.append(c); } left++; } return sb; }
public void reverse(StringBuilder sb, int left, int right) { while(left < right){ char tmp = sb.charAt(left); sb.setCharAt(left++, sb.charAt(right)); sb.setCharAt(right--, tmp); } }
public void reverseWord(StringBuilder sb){ int n = sb.length(); int start = 0, end = 0; while(start < n){ while(end < n && sb.charAt(end) != ' ') end++; reverse(sb, start, end - 1); start = end + 1; end++; } } }
|