我遇到了从Array排序字符串的问题。我能够对整数进行排序,但是我真的不知道如何将字符串从最短到最长排序。
我尝试使用Strings.length将Strings转换为整数,但是我不知道如何将其转换回其原始String。
String Handler;
System.out.println("\nNow we will sort String arrays.");
System.out.println("\nHow many words would you like to be sorted.");
Input = in.nextInt();
int Inputa = Input;
String[] Strings = new String [Input];
for (int a = 1; a <= Input; Input --) //will run however many times the user inputed it will
{
counter ++; //counter counts up
System.out.println("Number " + counter + ": "); //display
userinputString = in.next();
Strings[countera] = userinputString; //adds input to array
countera ++;
}
System.out.println("\nThe words you inputed are :");
System.out.println(Arrays.toString(Strings));
System.out.println("\nFrom shortest to longest the words are:");
counter = 0;
int[] String = new int [Strings.length];
for (int i = 0; i < Strings.length; i++) //will run however many times the user inputed it will
{
int a = Strings[i].length();
String[i] = a;
}
System.out.println(Arrays.toString(String));
我希望能够对实际的String进行排序,但是我正在获取数字,并且无法找到如何在排序后将这些数字转换回其字符串。
答案 0 :(得分:4)
如果允许使用库函数,则可能需要执行以下操作:
Arrays.sort(Strings, Comparator.comparing(String::length));
这在Java 8及更高版本中有效。只需确保在文件中的某个时刻导入import java.util.*;
。
答案 1 :(得分:0)
由于仅存储长度,因此无法转换它们-可能有许多长度相同的不同字符串。 取而代之的是,您可以尝试实现自己的比较器并将其传递给java的sort方法:如果第一个字符串较长,则给定两个字符串,如果相等则返回0,如果相等则返回-1。您也可以在传递给Arrays.sort()的lambda比较器中进行此操作。
(s1, s2) -> {
if (s1.length() < s2.length()) {
return -1;
}
return s1.length() > s2.length();
}