我正在解决spoj上的问题,这是URL http://www.spoj.com/problems/FACEFRND/
但是遇到错误并且无法识别我的错误,代码如下:
import java.util.ArrayList;
import java.util.Scanner;
public class Facefrnd {
public static void main(String args[]){
Scanner sc = new Scanner(System.in);
ArrayList<Integer> f = new ArrayList<Integer>();
ArrayList<Integer> fof = new ArrayList<Integer>();
int n, t, id, m;
n = sc.nextInt();
t = n;
while(t>0){
t--;
id = sc.nextInt();
m = sc.nextInt();
f.add(id);
if(fof.contains(id))
fof.remove(id);
for(int j = 0; j < m; j++){
id = sc.nextInt();
if(!f.contains(id))
fof.add(id);
}
}
System.out.print(fof.size());
}
}
错误与样本输入有关:
3
2334 5 1256 4323 7687 3244 5678
1256 2 2334 7687
4323 5 2334 5678 6547 9766 9543线程“主”中的异常java.lang.IndexOutOfBoundsException:索引:1256,大小:5
在java.util.ArrayList.rangeCheck(ArrayList.java:635)
在java.util.ArrayList.remove(ArrayList.java:474)
在sampleproject.Facefrnd.main(Facefrnd.java:22)
类型的Arraylist.remove()
方法默认为带有索引的remove 。为了删除它,您可以执行以下操作:ArrayLists
Integer
fof.remove(new Integer(id));
这样可以确保remove(Object o)
调用该方法。
样例代码:
ArrayList<Integer> test = new ArrayList<Integer>();
test.add(123);
test.remove(new Integer(123));
System.out.println(test.size());
这将打印“ 0”。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句