剑指 Offer 58 - I. 翻转单词顺序
剑指 Offer 58 - I. 翻转单词顺序
题目
链接
https://leetcode-cn.com/problems/fan-zhuan-dan-ci-shun-xu-lcof/
问题描述
输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. ",则输出"student. a am I"。
示例
输入: "the sky is blue"
输出: "blue is sky the"
提示
无空格字符构成一个单词。
输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。
思路
双指针法,首先都在右侧,向左找到空格或者到头为结束,在新的字符串中添加这两个指针中间的字符,之后找到下一个单词的右侧。
复杂度分析
时间复杂度 O(n)
空间复杂度 O(n)
代码
Java
public String reverseWords(String s) {
s = s.trim();
int right = s.length() - 1;
int left = right;
StringBuffer str = new StringBuffer();
while (left >= 0) {
while (left >= 0 && s.charAt(left) != ' ') {
left--;
}
str.append(s.substring(left + 1, right + 1) + " ");
while (left >= 0 && s.charAt(left) == ' ') {
left--;
}
right = left;
}
return str.toString().trim();
}