我试图解决一个问题,它被表述为 -> 给定一个数组 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]
答案 0 :(得分:0)
A.size()
是 0
,因为列表中还没有元素。数组应该用一个起始值初始化,列表 (ArrayLists) 不是。
您应该在没有容量的情况下初始化您的 ArrayList:
ArrayList<Integer> ans= new ArrayList<>();
然后你可以简单地
ans.add(-1);
或者更好的是,您可以简单地在方法的最后添加 -1
。
答案 1 :(得分:0)
ArrayList 构造函数用于初始容量,这不会用元素填充 ArrayList,大小为 0,直到插入或添加元素。