一.方法一 思想: 1.首先将字符串转换成字符数组,方便索引字符。 2.反转整个字符数组 3.反转每个单词,单词是如何划分的:维护一个单词的起始索引和结束索引i,j,分别表示一个单词的起始下标和结尾下标,对这个区间的字符数组进行反转。
public static void reverse(char[]arr,int i ,int j) {
//每个单词首位交换
while (i < j){
swap(arr, i ++, j --);
}
}
public static void swap(char[] arr, int i, int j){
char brr = arr[i];
arr[i] = arr[j];
arr[j] = brr;
}
public static void rev(String word){
char[] a = word.toCharArray();
int n = a.length;
reverse(a,0,n-1);
for (int i=0; i<n; ++i) {
int j = i;
for (; j<n && a[j]!=' '; j++);
reverse(a, i, j-1);
i = j;
}
System.out.println(a);
}
二.方法二 思想: 1.使用String的split方法,空格字符当分隔符,切割字符串存入一个字符串数组。 2.反转整个输入 3.遍历数据,拼接字符串,当不是最后一个元素时,中间添加空格
public static void main(String[] args) {
String s = "hello world ni hao shi jian";
String[] arr = s.split(" ");
int i=0, j=arr.length-1;
while (i < j) {
String x = arr[i];
arr[i] = arr[j];
arr[j] = x;
i ++;j--;
}
String res="";
for (int k=0; k<arr.length; ++k) {
res = res + arr[k];
if (k != arr.length-1) res += " ";
}
System.out.println(res);
}