写在前面:
题目的要求为:将输入字符串为"I am a Student.",转换输出为"Student. a am I".
那么这道题的思路是:
(1)翻转整个字符串,得到".tneduts a ma I"
(2)翻转每一个单词,得到“student. a am I"
接下来,我们看一下他的代码实现:
public String ReverseSentence(String str) {
if (str.trim().equals("") || str == null) {
return str;
}
// 第一步:翻转整个句子
String sentenceReverse = reverse(str);
String[] spilt = sentenceReverse.split(" ");
String result = "";
// 第二步:翻转每个单词
for (String i : spilt) {
result = result + reverse(i) + " ";
}
// 删除最后一个空格
result = result.substring(0, result.length() - 1);
return String.valueOf(result);
}
private String reverse(String str) {
char[] arr = str.toCharArray();
char temp;
for (int i = 0; i < arr.length / 2; i++) {
temp = arr[i];
arr[i] = arr[arr.length - i - 1];
arr[arr.length - i - 1] = temp;
}
return String.valueOf(arr);
}
总结:与这道题目类似的一个问题,《左旋转字符串》,我会在下一篇博客中,为大家总结,谢谢大家。