| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 469 人关注过本帖
标题:zoj 1586(Segmentation Fault )求指点
只看楼主 加入收藏
zh377254945
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2011-8-11
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
zoj 1586(Segmentation Fault )求指点
#include <stdio.h>
#include <malloc.h>
#define MaxVertices 250
#define MaxWeight 1000000


typedef struct
{
    int graph[MaxVertices];
    int edge[MaxVertices][MaxVertices];
    int numEdge;
    int numVer;
}AdjMGraph;


void Initiate(AdjMGraph * G,int n)
{
    int i,j;
    for(i=0;i<n;i++)
        for(j=0;j<n;j++)
            if(i==j)
                G->edge[i][j]=0;
            else
                G->edge[i][j]=MaxWeight;
    G->numEdge=0;
    G->numVer=n;
}

void InsertEdge(AdjMGraph * G,int v1,int v2,int weight)
{
    G->edge[v1][v2]=weight;
    G->edge[v2][v1]=weight;
    G->numEdge+=2;
}

int Prim(AdjMGraph G)
{
    int sum=0,minWeight,i,j,k,flag[MaxVertices];
    for(i=1;i<G.numVer;i++)
        flag[i]=G.edge[0][i];
    for(i=1;i<G.numVer;i++)
    {
        minWeight=MaxWeight;
        for(j=1;j<G.numVer;j++)
            if(flag[j]<minWeight&&flag[j]>0)
            {
                minWeight=flag[j];
                k=j;
            }
        sum+=minWeight;

        flag[k]=-1;
        for(j=1;j<G.numVer;j++)
            if(G.edge[k][j]<flag[j])
                flag[j]=G.edge[k][j];
    }
    return sum;
}


int main()
{
    int n,i,m,j,x;
    scanf("%d",&n);
    for(i=0;i<n;i++)
    {
        AdjMGraph G;
        scanf("%d",&m);
        Initiate(&G,m);
        for(j=0;j<m;j++)
            scanf("%d",&G.graph[j]);
        for(i=0;i<m;i++)
            for(j=0;j<m;j++)
            {
                scanf("%d",&x);
                if(x==0)
                    continue;
                G.edge[i][j]=x+G.graph[i]+G.graph[j];
            }
        printf("%d\n",Prim(G));
    }
    return 0;
}
搜索更多相关主题的帖子: void 1586 include 
2011-08-13 15:11
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:14 
全是英文的

                                         
===========深入<----------------->浅出============
2011-08-13 15:17
zh377254945
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2011-8-11
收藏
得分:0 
。。。。。。
2011-08-13 15:19
zh377254945
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2011-8-11
收藏
得分:0 
大体就是一个求最小生成树的问题,我用普里姆算法实现的,但是提交时出现了分段错误,无奈。。。。。。不知哪里错了,
2011-08-13 15:23
快速回复:zoj 1586(Segmentation Fault )求指点
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015922 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved