侧边栏壁纸
博主头像
阿里灰太狼博主等级

You have to believe in yourself . That's the secret of success.

  • 累计撰写 104 篇文章
  • 累计创建 50 个标签
  • 累计收到 12 条评论

目 录CONTENT

文章目录

leetcode-557. 反转字符串中的单词 III

阿里灰太狼
2021-12-02 / 0 评论 / 0 点赞 / 234 阅读 / 700 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2021-12-10,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

cj80.png

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

0

评论区