[编程题] 算法基础-字符移位
小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。
你能帮帮小Q吗?
输入描述:
输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.
输出描述:
对于每组数据,输出移位后的字符串。
输入例子:
AkleBiCeilD
输出例子:
kleieilABCD
注意
1 class必须是 Main
2 必须导包
思路
很简单 将大写的字母和小写的字母分别放进ArrayList
import java.util.ArrayList;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
while(sc.hasNext()){
System.out.println(getHW(sc.nextLine()));
}
}
public static String getHW(String str){
ArrayList<Character> low=new ArrayList<>();
ArrayList<Character> upper=new ArrayList<>();
StringBuffer sb=new StringBuffer();
for (int i = 0; i < str.length(); i++) {
if(str.charAt(i)>=65&&str.charAt(i)<97){
upper.add(str.charAt(i));
}else{
low.add(str.charAt(i));
}
}
for (Character character : low) {
sb.append(character);
}
for (Character character : upper) {
sb.append(character);
}
return sb.toString();
}
}