JAVA解法
class Solution {
public String reverseWords(String s) {
// 开辟一个新的字符串
StringBuffer ret = new StringBuffer();
// 获取字符串的长度 s
int length = s.length();
// 从 0 开始
int i = 0;
// 遍历字符串
while (i < length) {
// 每次的 i 都不一样,刚开始为 0
int start = i;
// 每次执行完这个循环,i 为单词的长度
while (i < length && s.charAt(i) != ' ') {
i++;
}
// 每个单词的起始索引不同(长度要减去一方为索引)
for (int p = start; p < i; p++) {
// 从单词尾部开始拼接
ret.append(s.charAt(start + i - 1 - p));
}
// 检测到空格,则在新的字符串中加空格
while (i < length && s.charAt(i) == ' ') {
i++;
ret.append(' ');
}
}
// 返回拼接后的字符串
return ret.toString();
}
}
题解分析
这道题首先开辟一个新的字符串并获取其长度,从头开始遍历字符串。由于每个单词的起始索引不一样,因此定义一个 start,把 i 的值赋给它,因为每次的 i 都不一样,刚开始为 0。
用 while 循环遍历字符串。再用一个 while 循环记录每次执行完循环的单词长度为 i,用 for 循环从单词尾部开始拼接,检测到空格时,则在新的字符串中加空格,最后返回拼接后的字符串,即达到反转字符串中的单词的目的。
leetcode原题: 557. 反转字符串中的单词 III
评论区