(java实现)
题目描述:
小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。
你能帮帮小Q吗?
输入描述:
输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.
输出描述:
对于每组数据,输出移位后的字符串。
示例1:
输入
AkleBiCeilD
输出
kleieilABCD
问题分析:
由于不能申请新的空间,只能在字符数组内进行操作。
思路一:使用java的replaceAll函数来实现;
思路二:使用StringBuilder();
思路三:直接分为两次输出,先输出小写字母,在输出大写字母,最后记得输出换行。
相关知识:
参考代码:
思路一实现:
import java.util.*;
public class Main {
public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
while (input.hasNext())
{
String str = input.nextLine();
System.out.println(str.replaceAll("[A-Z]+","")+str.replaceAll("[a-z]+",""));
}
}
}
思路二实现:
import java.util.*;
public class Main {
public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
while (input.hasNext())
{
StringBuilder str = new StringBuilder(input.nextLine());
int count = 0;
for (int i=0; i<str.length()-count; i++)
{
if (Character.isLowerCase(str.charAt(i)))
continue;
str.append(str.charAt(i)); //先加到末尾
str.delete(i,i+1); //再删除
count++;
i--; //由于有操作了,需要回退一个字符,不然会出错。
}
System.out.println(str.toString());
}
}
}
思路三实现:
import java.util.*;
public class Main {
public static void main(String[] args)
{
Scanner input = new Scanner(System.in);
while (input.hasNext())
{
String str = input.nextLine();
for (int i=0; i<str.length(); i++)
{
if (Character.isLowerCase(str.charAt(i)))
System.out.print(str.charAt(i));
}
for (int i=0; i<str.length(); i++)
{
if (Character.isUpperCase(str.charAt(i)))
System.out.print(str.charAt(i));
}
System.out.println();
}
}
}