给出一个通用类型列表(List),以及两个通用类型对象:a,b:
-设计一种算法,该算法返回一个列表,该列表包含原始列表中属于[a,b)范围的每个元素。
-该算法必须包含比较器E。
-解决方案必须是“分而治之”算法。
这是我想出的:
private static <E extends Comparable<E>> List <E> Dominio(List<E> lista,E a,E b){
return DominioAux(lista,a,b,lista.size()-1);
}
private static <E extends Comparable<E>> List <E> DominioAux(List<E> lista,E b,Integer i,Integer j){
List<E> res = new ArrayList<>();
Integer m = (j-i)/2;
E pm = lista.get(m);
if (pm == a) {
DominioAux(lista,m,j);
} else if(pm==b) {
DominioAux(lista,i,m-1);
}
if (pm.compareTo(a)<0) {
res = DominioAux(lista,j);
}
if (pm.compareTo(a)>0) {
res = DominioAux(lista,m);
}
res = lista.subList(i,j);
return res;
}
问题是当执行其中一个if时,我得到了“索引超出范围异常”或“堆栈溢出错误”。