151 反转字符串中的单词
2025年5月22日大约 2 分钟
🚀 相关链接
📜 描述
给你一个字符串 s
,请你反转字符串中 单词 的顺序。
单词 是由非空格字符组成的字符串。s
中使用至少一个空格将字符串中的 单词 分隔开。
返回 单词 顺序颠倒且 单词 之间用单个空格连接的结果字符串。
注意:输入字符串 s
中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。
💡 示例
- 输入:
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 <= 10^4
s
包含英文大小写字母、数字和空格' '
s
中 至少存在一个 单词
💭 思路
- 去除字符串的前导和尾随空格。
- 反转整个字符串。
- 反转每个单词,并去除多余的空格。
💻 代码实现
public String reverseWords(String s) {
StringBuilder sb = new StringBuilder(s.trim());
if (sb.indexOf(" ") == -1) {
return sb.toString();
}
sb.reverse();
int start = 0;
for (int i = 0; i < sb.length(); i++) {
if (sb.charAt(i) == ' ') {
while (sb.charAt(i + 1) == ' ') {
sb.deleteCharAt(i + 1);
}
reverse(sb, start, i - 1);
start = i + 1;
}
}
if (start < sb.length() - 1) {
reverse(sb, start, sb.length() - 1);
}
return sb.toString();
}
public void reverse(StringBuilder sb, int start, int end) {
while (start < end) {
char temp = sb.charAt(start);
sb.setCharAt(start, sb.charAt(end));
sb.setCharAt(end, temp);
start++;
end--;
}
}