我试图通过使用成本邻接矩阵来测试Prim's和Kruskal算法的实现。我将根据图中顶点的数量以及图中边的数量生成这些矩阵。它不必是一个连通图。生成随机对称加权邻接矩阵
这是我到目前为止有:
final static int infinity = 2000000000;
public static int[][] genAdjMat(int V, int E) {
int[][] a = new int[V][V];
int e = E;
for(int i = 0; i < V; i++) {
for(int j = i; j < V; j++) {
if(i == j) {
a[i][j] = 0;
}
else {
if(Math.random() < 0.5 && e >= 0) {
int temp = (int)Math.ceil(Math.random()*e);
a[i][j] = temp;
a[j][i] = temp;
e--;
}
else {
a[i][j] = infinity;
a[j][i] = infinity;
}
}
}
}
return a;
}
眼下,它会产生一个对称的数组,但它不使用我指定的所有边缘。我很难弄清楚如何使用所有边缘,并且仍然让它们随机放置在整个矩阵中,同时保持对称性。
做相反的事情。初始化一个空矩阵并添加'E'个随机边。 –
哇,我觉得很愚蠢。这很简单,谢谢给我另一种方式来做到这一点! –