gpt4 book ai didi

Java Arraylist问题从一处更改导致另一处

转载 作者:行者123 更新时间:2023-12-02 06:38:28 25 4
gpt4 key购买 nike

我一直在做一个项目,并且在java中遇到了Arraylist的问题。问题出在 prim 的算法上1. 随机生成图2. 为每个顶点创建一个邻居数组列表3. 将 arraylist 传递给 2 个不同的函数

问题:-当我在一个类中的 Arraylist 中进行更改时,它也反射(reflect)了其他类。如何修复它?预先感谢。当我调用 mst.java g.getneighbourlist() 时,它工作正常。但是现在,当我使用相同的 g.getbeighbourlist() 调用 mstFheap.java 及其不同的邻居列表时,我的意思是从第二个中删除第一个选择的所有边。

         //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()+" ");
}

}

最佳答案

尝试:

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

这将为每个算法创建列表的副本。

旁注:请以大写字母开头命名类。并考虑使用人类可读的名称。 “g”是Graph,那为什么不叫它“graph”呢?

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

关于Java Arraylist问题从一处更改导致另一处,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19397983/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com