按照單詞翻轉字串
1. 問題描述:
例如:從控制檯輸入here are you,輸出you are here
思路是使用Java提供翻轉字串的方法,先翻轉整個字串,然後使用正則表示式對翻轉後的字串進行分割,這裡使用空格分割,然後把分割後的結果儲存到一個String陣列中,之後再for迴圈中遍歷然後再把每個單詞翻轉回來,具體的程式碼如下:
import java.util.Scanner;
public class Main{
//測試用例: here are you
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
solve(str);
}private static void solve(String str) {
String s = reverseString(str);// 匹配多個空格的正則表示式regex = "\\s+"
String words[] = s.split("\\s+");
StringBuilder sb = new StringBuilder();
for(int i = 0; i < words.length; i++){//加入翻轉後的單詞
sb.append(reverseString(words[i])+" ");
}
System.out.println(sb.toString());
}private static String reverseString(String str) {
StringBuilder sb = new StringBuilder(str);
return sb.reverse().toString();
}
}
也可以這樣寫:先分割最開始的字串串然後遍歷最開始的字串遇到空格加入空格,具體的程式碼如下:
import java.util.Scanner;
public class Main{
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
solve(str);
}private static void solve(String str) {
String words[] = str.split("\\s+");
StringBuilder sb = new StringBuilder();
int count = words.length - 1;
for(int i = str.length() - 1; i>=0; i--){
if(str.charAt(i) == ' '){
sb.append(words[count--] + " ");
}
int j = i;
while(str.charAt(j--) == ' ');
i = j + 2;
}
sb.append(words[0]);
System.out.println(sb.toString());
}
}
有時候需要對其中單詞之間的多個空格也要進行輸出,此時就需要在迴圈中記錄空格的數量然後加入到字串中,具體的程式碼如下:
import java.util.Scanner;
public class Main{
//測試用例: here are you
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
solve(str);
}private static void solve(String str) {
String words[] = str.split("\\s+");
StringBuilder sb = new StringBuilder();
int count = words.length - 1;
for(int i = str.length() - 1; i >= 0 ; i--){
if(str.charAt(i) == ' '){
int j = i;
sb.append(words[count--]);
while(str.charAt(j--) == ' '){
sb.append(str.charAt(j + 1));
}
i = j + 2;
}
}
sb.append(words[0]);
System.out.println(sb.toString());
}
}