我试图创建一个程序,它接受用户输入并按字母顺序排序,因为它使用compareTo
String
(不是array.sort
)并在最后打印最终的已排序数组。我已经掌握了这个问题的大部分内容,但是一旦我进入排序功能就会丢失。有没有人对我如何能够完成SortInsert
方法有任何想法?将字符串插入到Java中的数组中插入字段
import java.util.*;
public class SortAsInserted {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int array_size = GetArraySize();
String[] myArray = new String[array_size];
for (int i = 0; i < array_size; i++){
String nextString = GetNextString();
String[] sortedArray = SortInsert(nextString, myArray);
}
PrintArray(sortedArray);
}
input.close();
}
}
public static String[] SortInsert(String nextString, String[] myArray){
for(int i = 0; i < myArray.length;)
if (nextString.compareToIgnoreCase(myArray[i]) > 0) {
i++;
//if current text is less(alphabetically) than position in Array
}else if (nextString.compareToIgnoreCase(myArray[i]) < 0){
}
}
public static int GetArraySize(){
Scanner input = new Scanner(System.in);
System.out.print("How many items are you entering?: ");
int items_in_array = input.nextInt();
return items_in_array;
}
public static void PrintArray(String[] x) {
for (int i = 0; i < x.length; i++){
System.out.print(x[i]);
}
}
public static String GetNextString(){
Scanner input = new Scanner(System.in);
System.out.println("Enter the next string: ");
String next_string = input.nextLine();
return next_string;
}
}
为什么要按照您的要求进行排序?最后一次排序意味着您不必每次都移动所有后来的字符串,甚至可以在原地进行排序。如果您确实需要随时对其进行排序,则应使用链接列表或其他一些不需要移动插入内容的其他数据结构。 –
这是我正在上课的任务。我不希望这样做,因为它很麻烦,但它是要求的一部分。 – Efie