前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >剑指Offer LeetCode 面试题58 - I. 翻转单词顺序

剑指Offer LeetCode 面试题58 - I. 翻转单词顺序

作者头像
手撕代码八百里
发布2020-07-28 23:01:31
6330
发布2020-07-28 23:01:31
举报
文章被收录于专栏:猿计划猿计划

面试题58 - I. 翻转单词顺序

输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. “,则输出"student. a am I”。

示例 1:

输入: “the sky is blue” 输出: “blue is sky the” 示例 2:

输入: " hello world! " 输出: “world! hello” 解释: 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。 示例 3:

输入: “a good example” 输出: “example good a” 解释: 如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。

说明:

无空格字符构成一个单词。 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。 如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。

解题

代码语言:javascript
复制
class Solution {
    public String reverseWords(String s) {
        
        if(s.equals("") ){ //如果直接是一个""的字符串,就直接返回""
            return "";
        }

        String[] s1 = s.split(" ");//按空格进行分割

        if(s1.length==0)// 如果分割后的长度为0,则代表输入的可能是:"  " 或者"         "全是空格的
            return ""; //那就直接返回""

        String str = "";

        //倒序输出
        for (int i = s1.length-1; i >=0 ; i--) {
            if(!s1[i].equals("")){
                str = str + s1[i]+" ";
            }
        }

        return str.substring(0,str.length()-1);
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-05-28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 面试题58 - I. 翻转单词顺序
  • 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档