【问题描述】编写一个程序,从键盘接收一个字符串,然后按照字符顺序从小到大进行排序,并删除重复的字符。
【输入形式】用户在第一行输入一个字符串。
【输出形式】程序按照字符(ASCII)顺序从小到大排序字符串,并删除重复的字符进行输出。
【样例输入】badacgegfacb
【样例输出】abcdefg
【样例说明】用户输入字符串badacgegfacb,程序对其进行按从小到大(ASCII)顺序排序,并删除重复的字符,最后输出为abcdefg
题目描述清晰,本题解题时应先将字符串转变成字符数组,然后在对字符数组进行排序去重,具体分为了2个小函数。
代码如下:
import java.util.Scanner;
public class Test2 {
static void soft(char []ch) {
for(int i=0;i<ch.length-1;i++) {
for(int j=0;j<ch.length-i-1;j++) {
if(ch[j]>ch[j+1]) {
char c=ch[j];
ch[j]=ch[j+1];
ch[j+1]=c;
}
}
}
}
static void overwrite(char[]ch) {
char []ch2=new char[ch.length];
ch2[0]=ch[0];
int length=1;
for(int i=1;i<ch.length;i++) {
if(ch[i]!=ch[i-1]) ch2[length++]=ch[i];
}
for(int i=0;i<length;i++)
System.out.print(ch2[i]);
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner scanner=new Scanner(System.in);
String string;
string=scanner.nextLine();
char []ch=string.toCharArray();
soft(ch);
overwrite(ch);
}
}