小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。
你能帮帮小Q吗?
输入描述:
输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.
输出描述:
对于每组数据,输出移位后的字符串。
示例1
输入
AkleBiCeilD
输出
kleieilABCD
解法一 :遍历两次字符串 第一次打印小写字母 第二次打印大写字母
import java.util.*;
public class Main{public static void main(String arg[]){
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
String str = sc.nextLine().trim();
for(int i=0;i<str.length();i++){
if(str.charAt(i)>='a'&&str.charAt(i)<='z'){
System.out.print(str.charAt(i));
}
}
for(int j=0;j<str.length();j++){
if(str.charAt(j)>='A'&&str.charAt(j)<='Z'){
System.out.print(str.charAt(j));
}
}
System.out.print("\n");
}
sc.close();
}
}
解法二:不用遍历 直接使用replaceAll函数
import java.util.*;
public class Main{
public static String getResult(String str){
return str.replaceAll("[A-Z]","")+str.replaceAll("[a-z]","");
}
public static void main(String arg[]){
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
String str = sc.nextLine().trim();
System.out.println(getResult(str));
}
sc.close();
}
}