【剑指offer】翻转单词序列

描述
牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“nowcoder. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a nowcoder.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?

示例1
复制
返回值:
“I am a nowcoder.”

代码

package Offer;

import java.util.Stack;

/**
 * 翻转单词序列
 * 描述
 * 牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。
 * 同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。
 * 例如,“nowcoder. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,
 * 正确的句子应该是“I am a nowcoder.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?
 * <p>
 * 示例1
 * 输入:
 * "nowcoder. a am I"
 * <p>
 * 返回值:
 * "I am a nowcoder."
 */
public class J44_ReverseSentence {

    public static String ReverseSentence1(String str) {
        StringBuilder sb = new StringBuilder();
        if (str.length() < 0 || str.trim().equals("")) {//判断全是空格
            return str;
        }
        String[] arr = str.split(" ");
        for (int i = arr.length - 1; i > 0; i--) {
            sb.append(arr[i] + " ");
        }
        sb.append(arr[0]);
        return sb.toString();
    }

    public static String ReverseSentence2(String str) {
        if (str == null | str.length() == 0) {
            return str;
        }
        StringBuilder sb = new StringBuilder();
        String[] arr = str.split(" ");
        if (arr.length == 0) {
            return str;//判断全是空格
        }
        Stack<String> stack = new Stack<>();
        for (int i = 0; i < arr.length - 1; i++) {
            stack.push(arr[i]);
            stack.push(" ");
        }
        stack.push(arr[arr.length - 1]);
        while (!stack.isEmpty()) {
            sb.append(stack.pop());
        }
        return sb.toString();
    }

    public static void main(String[] args) {
        String res1 = ReverseSentence1("nowcoder. a am I");
        System.out.println(res1);
        String res2 = ReverseSentence2("nowcoder. a am I");
        System.out.println(res2);
    }
}

版权声明:本文为weixin_44026997原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。