小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。
你能帮帮小Q吗?
输入描述:
输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.
输出描述:
对于每组数据,输出移位后的字符串。
输入例子1:
AkleBiCeilD
输出例子1:
kleieilABCD
解题思路:
利用插入排序的思想进行可以保证有序性。
import java.util.*;
public class Main{
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
while(sc.hasNext()){
StringBuilder str = new StringBuilder(sc.nextLine());
for(int i=1; i<str.length(); i++){
for(int j=i; j>0; j--){
//如果考察的字符已经是大写,则跳出内循环
if(str.charAt(j)>='A' && str.charAt(j)<='Z')
break;
//如果考察元素的前一个元素为大写则需要交换
if(str.charAt(j-1)>='A' && str.charAt(j-1)<='Z'){
//交换下标j与j-1的字符
char temp = str.charAt(j-1);
str.setCharAt(j-1, str.charAt(j));
str.setCharAt(j, temp);
}
}
}
System.out.println(str);
}
}
}