线程“main”中的异常 java.lang.IndexOutOfBoundsException: Index: 8, Size: 0 at java.util.ArrayList.rangeCheckForAdd(ArrayList.java:665)

时间:2021-04-08 17:46:58

标签: java arraylist runtime-error indexoutofboundsexception

我试图解决一个问题,它被表述为 -> 给定一个数组 A,为数组中的每个元素 A[i] 找到下一个更大的元素 G[i]。元素 A[i] 的下一个较大元素是数组 A 中 A[i] 右侧的第一个较大元素。对于不存在较大元素的元素,将下一个较大元素视为 -1。

public class Solution {
    public ArrayList<Integer> nextGreater(ArrayList<Integer> A) {
       Stack<Integer> stk = new Stack<>();
       if (A.size() == 1)
        {
            ArrayList<Integer> ans= new ArrayList<>();
            ans.add(0,-1);
            return ans;
        }
       ArrayList<Integer> ans= new ArrayList<>(A.size());
       ans.add(A.size()-1,-1); //error ->Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 8, Size: 0
       stk.push(0);
       for(int i=1;i<A.size()-1;i++){
               while(!stk.isEmpty()&&A.get(i)>A.get(stk.peek())){
                   ans.add(stk.pop(),A.get(i));
                //   stk.pop();
               }
               stk.push(i);
           }
       return ans;
    }
}

但是在解决这个问题时,我不明白为什么在位置 A.size()-1 的数组列表中添加 -1 时出现错误,其中 A : [ 34, 35, 27, 42, 5, 28, 39, 20, 28]

2 个答案:

答案 0 :(得分:0)

A.size()0,因为列表中还没有元素。数组应该用一个起始值初始化,列表 (ArrayLists) 不是。 您应该在没有容量的情况下初始化您的 ArrayList: ArrayList<Integer> ans= new ArrayList<>();

然后你可以简单地 ans.add(-1);

或者更好的是,您可以简单地在方法的最后添加 -1

答案 1 :(得分:0)

ArrayList 构造函数用于初始容量,这不会用元素填充 ArrayList,大小为 0,直到插入或添加元素。