Java Arraylist问题在一个地方发生变化导致另一个地方

时间:2013-10-16 07:55:54

标签: java arraylist

我一直致力于一个项目,我在java中遇到了Arraylist的问题。 问题是prim的算法 1.随机生成图形 2.为每个顶点制作邻居的arraylist 3.将arraylist传递给2个不同的函数

问题: - 当我在一个类中对Arraylist进行更改时,它反映的是其他类。怎么解决?在此先感谢。在我打电话给mst.java g.getneighbourlist()时,它运行正常。但是现在当我使用相同的g.getbeighbourlist()调用mstFheap.java时,其不同的neibourlist我的意思是所有选择的边缘首先从第二个中删除。

         //main.java

                 public class main{
                    GenGraph g = new GenGraph(size, density);
        g.makeGraph();
        g.print();
        // calling for finding mst
        mst m= new mst(g.getNeighbourlist(),size);
        mstFheap m1= new mstFheap(g.getNeighbourlist(), size);

        m.start(); // starts the algo
        m.print(); // print mst
        m1.print(); // In second class just printing the neibhour list
                   }

        //mst.java

         public class mst {
private List<LinkedList<edge>> neighbour =null;
private LinkedList<edge> mst = new LinkedList<edge>();
private int [] traker = null;
private int totalCost =0;
private int size=0;
private boolean path=false;

public mst(List<LinkedList<edge>> list,int x)
{
    this.neighbour=new ArrayList<LinkedList<edge>>(list);;
    this.size=x;
    this.traker= new int[size];
    for(int i=0;i<size;i++){traker[i]=0;}

}

            public void start() {

    List<Integer> subGroup = new ArrayList<Integer>();
    Random ran= new Random();
    int val= ran.nextInt(size);
    subGroup.add(val);
    traker[val]=1;
    while(!path){
        edge e= minCost(subGroup);
        totalCost+= e.weight;
        subGroup.add(e.v2);
        neighbour.get(e.v1).remove(e);
        edge temp = new edge(e.v2,e.v1,e.weight);
        neighbour.get(e.v2).remove(temp);
        traker[e.v1]=1;
        traker[e.v2]=1;
        mst.add(e);
        if(subGroup.size()==size) path=true;
    }

}

        //mstFheap.java

           public class mstFheap {
         private fHeap f;
         private double totalCost =0;
         private double [] keyList= null;

//Graph elements
private int size=0;
private List<LinkedList<edge>> neighbour =null;
public double cost(){return totalCost;}


public mstFheap(List<LinkedList<edge>> list,int size){
    f=new fHeap();
    neighbour=new ArrayList<LinkedList<edge>>(list);
    this.size=size;
    keyList=new double[size];       
        for(int i=0;i<size;i++){
            keyList[i]= Double.POSITIVE_INFINITY;
            fHeapNode temp= new fHeapNode(i, keyList[i]);
            f.insert(temp, keyList[i]);
            }
    }

            public void print(){
    System.out.print(" Keylist:-  ");
    for(int i=0;i<neighbour.size();i++){
        System.out.print(neighbour.get(i).size()+" ");
    }

}

1 个答案:

答案 0 :(得分:2)

尝试:

mst m= new mst(new ArrayList(g.getNeighbourlist()),size);
mstFheap m1= new mstFheap(new ArrayList(g.getNeighbourlist()), size);

这将为每个算法制作一份列表副本。

SideNote:请输入以大写字母开头的课程。并考虑使用人类可读的名称。 “g”是Graph,为什么不把它称为“图形”?

编辑:我刚才看到,它是一个“列表清单”。因此,您可以调整getNeighbourlist()方法,以便返回“深层复制”。这意味着:您必须返回一个新的条目清单副本列表,而不是列表的副本。