如何为从控制台输入的 ArrayList 元素实现 boolean isSorted?

How to implement boolean isSorted for ArrayList elements being input from console?

列表是否已排序?

编写一个程序来检查列表是否已经排序。对于要排序的列表,下一个元素不能小于前一个元素

输入

在第一行 - 您将收到一个数字 N。

在接下来的 N 行中,您将收到一个数字列表,以逗号分隔

输出

有N行输出

对于您收到的每个列表,如果已排序则打印 'true' 否则打印 'false'。

约束条件

1 <= N <= 10

1 <= list.length <= 20

代码:

  import java.util.ArrayList;
  import java.util.Scanner;

  public class Main {

      static public boolean isSorted(ArrayList<Integer> list) {
         boolean sorted = false;
         for (int i = 1; i< list.size(); i++){
         if (list.get(i-1)<list.get(i)) sorted = true;
      }
       return sorted;
   }

     public static void main(String[] args) {
     
     ArrayList<String> inputs = createList();
     ArrayList<Integer> resultList = transformList(inputs);
     printList(resultList);
  }

   public static ArrayList<String> createList() {
      Scanner scanner = new Scanner(System.in);
       int length = scanner.nextInt();
      ArrayList<String> list = new ArrayList<>();
        while(length-->-1){
            String input = scanner.nextLine();
            list.add(input.replaceAll(",",""));
        }
        return list;
   }

    public static ArrayList<Integer> transformList(ArrayList<String> stringArrayList){
      ArrayList<Integer> result = new ArrayList<>();
        for (int i = 1; i< stringArrayList.size(); i++){
          result.add(Integer.parseInt(stringArrayList.get(i)));
      }
       return result;
   }

   public static void printList(ArrayList<Integer> list){
      for (int  i = 0; i< list.size(); i++){
          System.out.println(isSorted(list));
      }
   }
}

输入

3

1,2,3,4,5

1,2,8,9,9

1,2,2,3,2

我的输出结果不正确:

正确

正确

正确

预期输出应该如下所示:

正确

正确

错误

请给我一个提示,让我正确地实现 isSorted 方法。

注意: 我需要实现它 没有 Guava Ordering class .

认为您只需要一个 else 语句。一旦 sorted 为真,如果其他值未按排序顺序,则 return 似乎永远不会为假。因此 1,2,2,3,2 的问题。最初 sorted 是 true 但当将 3 与 2 sorted 进行比较时假设为 false,您尚未将其设置为

static public boolean isSorted(ArrayList<Integer> list) {
         boolean sorted = false;
         for (int i = 1; i< list.size(); i++){
         if (list.get(i-1)<list.get(i))
              sorted = true;
         else{
             sorted = false;
          }

      }
       return sorted;
   }

如果未排序,您应该更新 sorted 值。

static public boolean isSorted(ArrayList<Integer> list) {
    boolean sorted = false;

    for (int i = 1; i < list.size(); i++) {
        sorted = list.get(i - 1) <= list.get(i);
    }

    return sorted;
}

无需遍历整个列表。一旦发现 list.get(i-1)>list.get(i) 表示列表未排序,就可以跳出循环。

static public boolean isSorted(ArrayList<Integer> list) {
boolean sorted = true;
for (int i = 1; i < list.size(); i++) {
  if (list.get(i - 1) > list.get(i)) {
    sorted = false;
    break;
  }
}
return sorted;

}