题解 | #句子逆序#

句子逆序

http://www.nowcoder.com/practice/48b3cb4e3c694d9da5526e6255bb73c3

思路: 这道题,其实有更简单的方法。但是呢,为了适合类似的、比这道题 要求更多难度更大 的一类题目,因此我使用了以下的方法。

所谓的要求更多的、难度更大,有以下几种:

  1. 所有单词之间不再是只有一个空格隔开,有可能有多个。这个时候,如果一再使用 .split(" ") 直接分割,会出问题的。因此,需要我们自行的判断字符串中,哪一段是空格,哪一段是单词
  2. 不再是句子逆序,而是 单个单词逆序。也就是说,如果输入数据是 I am a boy,那么最终的输出结果应该是 I ma a yob

综上所示,以下代码只是能够适应更多的题目,并不是本题的最优解法!

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        String str = scan.nextLine();
        char[] chrs = str.toCharArray();
        Stack<String> stack = new Stack<>();
        StringBuffer sb = new StringBuffer("");
        int sign = 0;
        int start = 0;
        for (int i = 0; i < chrs.length; i++) {
            char currentChar = chrs[i];
            if (currentChar == ' ') {
                if (sign == 1) {
                    sign = 0;
                    stack.push(str.substring(start, i));
                }
                stack.push(" ");
            } else {
                if (sign == 0) {
                    sign = 1;
                    start = i;
                }
            }
        }
        if (sign == 1) {
            stack.push(str.substring(start));
        }
        while (!stack.isEmpty()) {
            sb.append(stack.pop());
        }
        System.out.println(sb);
    }
}
全部评论
该牛油正在参与牛客写题解薅羊毛的活动,牛币,周边,京东卡超多奖品放送,活动进入倒计时!快来捡漏啦https://www.nowcoder.com/discuss/888949?source_id=profile_create_nctrack&channel=-1
点赞 回复 分享
发布于 2022-04-20 16:20

相关推荐

找工作勤劳小蜜蜂:自我描述部分太差,完全看不出想从事什么行业什么岗位,也看不出想在哪个地区发展,这样 会让HR很犹豫,从而把你简历否决掉。现在企业都很注重员工稳定性和专注性,特别对于热爱本行业的员工。 你实习的工作又太传统的it开发(老旧),这部分公司已经趋于被淘汰,新兴的互联网服务业,比如物流,电商,新传媒,游戏开发和传统的It开发有天然区别。不是说传统It开发不行,而是就业岗位太少,基本趋于饱和,很多老骨头还能坚持,不需要新血液。 工作区域(比如长三角,珠三角,成渝)等也是HR考虑的因素之一,也是要你有个坚定的决心。否则去几天,人跑了,HR会被用人单位骂死。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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