无法实现Brovuka的算法来寻找MST

时间:2014-04-10 01:23:57

标签: c++ algorithm minimum-spanning-tree

我不知道为什么在运行代码时,在第一个循环中的find函数中存在访问冲突,我有点丢失,这是我的代码,如果你们有任何现有的brovuka的c ++或java实现存在吗?

#include <iostream>
using namespace std;

int numVertices,numEdges;
int *parent,*weight,numTrees;
int *bestEdgeNum;

struct edge {
    int tail,head,weight;
};
typedef struct edge edgeType;
edgeType *edgeTab;

int find(int x)
{
    int i,j,root;

    for (i=x;parent[i]!=i; i=parent[i]);
        root=i;
    // path compression 
    for (i=x; parent[i]!=i;j=parent[i],parent[i]=root,i=j);
    return root;
}

void makeEquivalent(int i,int j)
{
    if (weight[i]>weight[j])
    {
        parent[j]=i;
        weight[i]+=weight[j];
    }
    else
    {
        parent[i]=j;
        weight[j]+=weight[i];
    }
    numTrees--;
}

int main()
{
    int i,MSTweight=0;
    int root1,root2;
    int usefulEdges;

    cout << "Enter the number of Vertices\n";
    cin >> numVertices;
    cout << "Enter the number of Edges\n";
    cin >> numEdges;

    edgeTab = new edgeType[numEdges];
    parent = new int[numVertices];
    weight = new int[numVertices];
    bestEdgeNum = new int[numVertices];

    if (!edgeTab || !parent || !weight || !bestEdgeNum)
    {
        cout << "error\n";
    }

    cout << "Enter the undirected edge weights for the graph in the format u v w\n";
    for (i=0;i<numEdges;i++)
    {
        cin >> edgeTab[i].tail >> edgeTab[i].head  >> edgeTab[i].weight;
    }
    for (i=0;i<numVertices;i++)
    {
        parent[i]=i;
        weight[i]=1;
    }
    numTrees=numVertices;  // Each vertex is initially in its own subtree
    usefulEdges=numEdges;  // An edge is useful if the two vertices are separate
    while (numTrees>1 && usefulEdges>0)
    {
        for (i=0;i<numVertices;i++)
            bestEdgeNum[i]=(-1);
        usefulEdges=0;
        for (i=0;i<numEdges;i++)
        {
            root1=find(edgeTab[i].tail);
                    root2=find(edgeTab[i].head);
                    if (root1==root2)
                        cout << edgeTab[i].tail <<" , " <<  edgeTab[i].head << " : "
                             << edgeTab[i].weight << " is useless\n";
                    else
                    {
                        usefulEdges++;
                        if (bestEdgeNum[root1] == -1||edgeTab[bestEdgeNum[root1]].weight>edgeTab[i].weight)
                            bestEdgeNum[root1]=i;  // Have a new best edge from this component

            if (bestEdgeNum[root2]==(-1)|| edgeTab[bestEdgeNum[root2]].weight>edgeTab[i].weight)
                bestEdgeNum[root2]=i;  // Have a new best edge from this component
        }
    }
    for (i=0;i<numVertices;i++)
        if (bestEdgeNum[i]!=(-1))
        {
            root1=find(edgeTab[bestEdgeNum[i]].tail);
            root2=find(edgeTab[bestEdgeNum[i]].head);
            if (root1==root2)
                continue;  // This round has already connected these components.
            MSTweight+=edgeTab[bestEdgeNum[i]].weight;
            cout << edgeTab[bestEdgeNum[i]].tail << " " << edgeTab[bestEdgeNum[i]].head << " " << edgeTab[bestEdgeNum[i]].weight << "included in MST\n";    
            makeEquivalent(root1,root2);
                    }
                    cout << "numTrees is " << numTrees << endl;

    }
    if (numTrees!=1)
        cout << "MST does not exist\n";
    cout << "Sum of weights of spanning edges is " << MSTweight << endl;

    return 0;
}

1 个答案:

答案 0 :(得分:1)

您的问题是您以1种格式输入顶点,但所有阵列(例如父级)都是基于0的格式。当你试图让父母[4]发生坏事时。

最简单的修复方法可能是在输入时从头部和尾部减去1,然后在打印结果时再次添加1。