描述
牛客最近来了一个新员工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);
}
}