import java.util.Arrays;
import java.util.Scanner;
public class SortNum {
public static void main (String[] args){
Scanner input = new Scanner(System.in);
String str = "";
String [] arr = new String[10];
for (int i = 0; i <10 ; i++) {
System.out.println("请输入");
str = input.next();
// 判断是不是输入结束字符串
if(str.equals("END")){
break;
}else{
// 不是则存入数组
arr[i] = str;
}
}
sort(arr);
}
// 编写排序方法
public static void sort(String[]arr){
String s;
int j;
for (int i = 0; i <arr.length-1 ; i++) {
for (j = 0; j <arr.length-1-i ; j++) {
// 如果用户输入的不是十个,则会有null值,而null不需要
// 输出结果
if((arr[i] == null)){
continue;
}
if(compare(arr[j],arr[j+1])){
s = arr[j];
arr[j] = arr[j+1];
arr[j+1] = s;
}
}
}
System.out.println(Arrays.toString(arr));
}
// 进行字符之间的大小比较
public static boolean compare(String s1,String s2){
boolean flag = false;
int len;
if(s2.length()>s1.length()){
len = s1.length();
}else{
len = s2.length();
}
for (int i = 0; i < len; i++) {
if (s1.charAt(i) == s2.charAt(i)) {
continue;
}
if (s1.charAt(i) > s2.charAt(i)) {
return true;
} else {
return false;
}
}
return s1.length() > s2.length() ? false : true;
}
}
输入小于十个或十个字符串(直到输入END为止),根据ASCII码值的大小对其进行排序,并输出结果。
最新推荐文章于 2021-11-21 23:07:30 发布