题解 | #翻转单词序列#

翻转单词序列

https://www.nowcoder.com/practice/3194a4f4cf814f63919d0790578d51f3

1. Java API

import java.util.*;
public class Solution {
    public String ReverseSentence(String str) {
        int n = str.length();
        String[] words = str.split(" ");
        StringBuilder sb = new StringBuilder();
        for(int i = words.length - 1; i >= 0; i --){
            sb.append(words[i]).append(" ");
        }
        return sb.toString().trim();
    }
}

2. 双指针算法

public class Solution {
    public String ReverseSentence(String str) {
        str = str.trim(); // 删除首尾空格
        int j = str.length() - 1, i = j;
        StringBuilder res = new StringBuilder();
        while(i >= 0) {
            while(i >= 0 && str.charAt(i) != ' ') i--; // 搜索首个空格
            res.append(str.substring(i + 1, j + 1) + " "); // 添加单词
            while(i >= 0 && str.charAt(i) == ' ') i--; // 跳过单词间空格
            j = i; // j 指向下个单词的尾字符
        }
        return res.toString().trim(); // 转化为字符串并返回
    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 13:15
点赞 评论 收藏
分享
牛客38347925...:9,2学生暑期实习失利开始投小厂,给这群人整自信了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务