我编写了一个java代码,它有两个向量v1
和v2
。现在v1
和v2
都以包含类似v1.add("A",1,2)
或v2("B",3,4)
的格式的分组(假定(的形式存储数据,假定分组大小为3。现在,v2将检查其数据包是否已经在v1中。如果它在那里,则v2
将删除该分组,如果它不在v1
中,则该分组将被添加到v1
并将从v2
中删除。例如,v1["A",1,2]
和v2["A",1,1,"A",1,2]
。
现在,v2
将从"A"
开始。它将在v1
中找到A
。然后它将转到1
。再次,它将转到1
,并且v2
将在v1
中找不到1
。并且它将把("A",1,1)
添加到v1
并从v2
中删除它。因此,v1
代表["A",1,2,"A",1,1]
,v2
将与["A",1,2]
站在一起。现在v2将再次检查["A",1,2]
是否在v1
中。程序将从v1
开始进行检查。它将找到"A"
,然后是1
,然后是2
。因此v2
将从自身删除["A",1,2]
。这是我的代码:
package privatechecker;
import java.util.LinkedList;
import java.util.Vector;
public class Privatechecker {
public static void main(String[] args) {
int a=0,i=0,j=0,b=0,k=0;
Vector v1= new Vector();
Vector v2= new Vector();
v1.add("A");
v1.add(2);
v1.add(3);
v2.add("A");
v2.add(2);
v2.add(3);
v2.add("B");
v2.add(2);
v2.add(3);
v2.add("B");
v2.add(2);
v2.add(3);
v2.add("A");
v2.add(7);
v2.add(38);
v2.add("C");
v2.add(4);
v2.add(5);
v2.add("C");
v2.add(10);
v2.add(5);
v2.add("C");
v2.add(10);
v2.add(5);
do {
for(j=0;j<v1.size()-1;){
if(v2.get(i)== v1.get(j)){
i=i+1;
j=j+1;
a=0;
if(v2.get(i)== v1.get(j)){
i=i+1;
j=j+1;
a=0;
if(v2.get(i)== v1.get(j)){
System.out.println("Deleted "+v2.get(i));
v2.remove(i);
i=i-1;
System.out.println("Deleted "+v2.get(i));
v2.remove(i);
i=i-1;
System.out.println("Deleted "+v2.get(i));
v2.remove(i);
System.out.println("Buffered "+v2);
a=1;
i=0;
j=0;
}
else {
i=i-2;
j=j+1;
a=0;
}
}
else{
i=i-1;
j=j+2;
a=0;
}
}
else {
j=j+3;
i=0;
a=0;
}
}
if(a==0){
System.out.println("Added "+v2.get(i));
v1.add(v2.get(i));
v2.remove(0);
System.out.println("Added "+v2.get(i));
v1.add(v2.get(i));
v2.remove(0);
System.out.println("Added "+v2.get(i));
v1.add(v2.get(i));
v2.remove(0);
System.out.println("Stored "+v1);
System.out.println("Buffer "+v2);
i=0;
}
}
while(v2.isEmpty()==false);
System.out.println("Stored "+v1);
System.out.println("Buffered "+v2);
}
}
现在的问题是我得到
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: Array index out of range: 0
at java.util.Vector.get(Vector.java:748)
at privatechecker.Privatechecker.main(Privatechecker.java:53)
C:UsersUserAppDataLocalNetBeansCache8.2executor-snippetsrun.xml:53: Java returned: 1
我不知道为什么我会出现索引错误,因为我键入了几个打印命令来检查矢量元素是否正确。它们都是正确的,即使v1和v2具有我想要的确切元素。但正如错误所显示的那样,我无法在循环之外打印矢量。如何解决此问题?
问题的发生是因为v2为空后内部循环继续迭代。
考虑一下你的代码摘录:
do {
for(j=0;j<v1.size()-1;) {
if(v2.get(i)== v1.get(j)) {
...
}
while(v2.isEmpty()==false);
上面的for
循环对v1进行迭代。但里面的代码主体是从v2中删除条目,这允许v2在循环对v1进行迭代之前变为空。
我用来发现问题的方法:
- 错误消息
Array index out of range: 0
表示这可能是对空向量的get操作,因为只有当向量为空时,索引0才会超出范围 - 错误消息包括错误发生在哪一行:
if(v2.get(i)== v1.get(j)) {
- 由于有两个方法调用可能引发错误,我在不同的行上尝试了这些方法调用,以查看是哪一个导致了错误:
v2.get(i);
v1.get(j);
- 原来是
v2.get(i)
,所以我开始寻找在v2为空后可以访问的方法,这就是我研究for循环退出条件的原因
根据您的算法的设计目的,这可能是一个更复杂的条件,for循环是您的出路,或者您可能需要重新思考您的循环方法。