数据结构实验之图论六:村村通公路

Time Limit: 1000MS Memory limit: 65536K

题目描述

当前农村公路建设正如火如荼的展开,某乡镇政府决定实现村村通公路,工程师现有各个村落之间的原始道路统计数据表,表中列出了各村之间可以建设公路的若干条道路的成本,你的任务是根据给出的数据表,求使得每个村都有公路连通所需要的最低成本。

输入

连续多组数据输入,每组数据包括村落数目N(N <= 1000)和可供选择的道路数目M(M <= 3000),随后M行对应M条道路,每行给出3个正整数,分别是该条道路直接连通的两个村庄的编号和修建该道路的预算成本,村庄从1~N编号。 

输出

输出使每个村庄都有公路连通所需要的最低成本,如果输入数据不能使所有村庄畅通,则输出-1,表示有些村庄之间没有路连通。 

示例输入

5 8
1 2 12
1 3 9
1 4 11
1 5 3
2 3 6
2 4 9
3 4 4
4 5 6

示例输出

19

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_VERTEX_NUM 100  // 最大顶点个数
#define INFINITY 100000 // 用整型最大值代替∞
typedef int VRType;;
typedef int VertexType;
VRType sum,n,m,visited[1000];
// 邻接矩阵的数据结构
typedef struct
{VRType adj; // 顶点关系类型。对无权图,用1(是)或0(否)表示相邻否;// 对带权图,则为权值类型}ArcCell, AdjMatrix[MAX_VERTEX_NUM][MAX_VERTEX_NUM];// 图的数据结构
typedef struct
{VertexType vexs[MAX_VERTEX_NUM];   // 顶点向量AdjMatrix arcs;      // 邻接矩阵int vexnum,          // 图的当前顶点数arcnum;           // 图的当前弧数
} MGraph;// 记录从顶点集U到V-U的代价最小的边的辅助数组定义
typedef struct
{VertexType adjvex;VRType lowcost;
}minside[MAX_VERTEX_NUM];
// 算法7.2  P162
// 采用数组(邻接矩阵)表示法,构造无向网G。
int CreateAN(MGraph *G)
{int i,j,k,w,v1,v2;(*G).vexnum=n;(*G).arcnum=m;for(i=1;i<=(*G).vexnum;++i) // 初始化邻接矩阵for(j=1;j<=(*G).vexnum;++j){(*G).arcs[i][j].adj=INFINITY; // 网初始化为无穷大}for(k=1;k<=(*G).arcnum;++k){scanf("%d%d%d",&v1,&v2,&w);if(w<(*G).arcs[v1][v2].adj)(*G).arcs[v1][v2].adj=(*G).arcs[v2][v1].adj=w; // 无向}return 1;
}// 求closedge.lowcost的最小正值
int minimum(minside SZ,MGraph G)
{int i=1,j,k,min;while(!SZ[i].lowcost)i++;min=SZ[i].lowcost; // 第一个不为0的值k=i;for(j=i+1;j<=G.vexnum;j++)if(SZ[j].lowcost>0)if(min>SZ[j].lowcost){min=SZ[j].lowcost;k=j;}return k;
}// 算法7.9 P175
// 用普里姆算法从第u个顶点出发构造网G的最小生成树T,输出T的各条边
void MiniSpanTree_PRIM(MGraph G,VertexType u)
{int i,j,k;minside closedge;k=u;visited[k]=1;for(j=1;j<=G.vexnum;++j) // 辅助数组初始化{if(j!=k){closedge[j].adjvex=u;closedge[j].lowcost=G.arcs[k][j].adj;}}closedge[k].lowcost=0; // 初始,U={u}for(i=2;i<=G.vexnum;++i){ // 选择其余G.vexnum-1个顶点k=minimum(closedge,G); // 求出T的下一个结点:第K顶点if(closedge[k].lowcost!=INFINITY)visited[k]=1;sum=sum+closedge[k].lowcost;closedge[k].lowcost=0; // 第K顶点并入U集for(j=1;j<=G.vexnum;++j)if(G.arcs[k][j].adj<closedge[j].lowcost){// 新顶点并入U集后重新选择最小边closedge[j].adjvex=k;closedge[j].lowcost=G.arcs[k][j].adj;}}
}int main()
{int i;while(scanf("%d%d",&n,&m)!=EOF){memset(visited,0,sizeof(visited));sum=0;MGraph G;CreateAN(&G);MiniSpanTree_PRIM(G,1);for(i=1;i<=n;i++)if(visited[i]==0)break;if(i==n+1)printf("%d\n",sum);elseprintf("-1\n");}return 0;
}

数据结构实验之图论六:村村通公路相关推荐

  1. SDUT-3362 数据结构实验之图论六:村村通公路

    数据结构实验之图论六:村村通公路 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Discuss Problem Descripti ...

  2. 数据结构实验之图论六:村村通公路(最小生成树Prim/Kruskal)

    Description 当前农村公路建设正如火如荼的展开,某乡镇政府决定实现村村通公路,工程师现有各个村落之间的原始道路统计数据表,表中列出了各村之间可以建设公路的若干条道路的成本,你的任务是根据给出 ...

  3. 数据结构实验之图论七:驴友计划(最新版)

    数据结构实验之图论七:驴友计划 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 做为一个资深驴友,小新有一张珍藏的自驾游 ...

  4. 数据结构实验之图论九:最小生成树

    数据结构实验之图论九:最小生成树 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 有n个城市,其中有些城市之间可以修建公 ...

  5. oj 数据结构实验之图论三:判断可达性

    数据结构实验之图论三:判断可达性 Description 在古老的魔兽传说中,有两个军团,一个叫天灾,一个叫近卫.在他们所在的地域,有n个隘口,编号为1-n,某些隘口之间是有通道连接的.其中近卫军团在 ...

  6. SDUT_2121数据结构实验之链表六:有序链表的建立 (对建立的单项链表结构进行排序)

    点击打开链接 数据结构实验之链表六:有序链表的建立 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Discuss Problem ...

  7. SDUT-3378_数据结构实验之查找六:顺序查找

    数据结构实验之查找六:顺序查找 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 在一个给定的无序序列里,查找与给定关键字 ...

  8. 山东理工OJ【2121】数据结构实验之链表六:有序链表的建立(插排法)

     数据结构实验之链表六:有序链表的建立 Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^ 题目描述 输入N个无序的整数,建立一个有序链表, ...

  9. SDUT-2121_数据结构实验之链表六:有序链表的建立

    数据结构实验之链表六:有序链表的建立 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 输入N个无序的整数,建立一个有序链 ...

最新文章

  1. 【cs229-Lecture2】Linear Regression with One Variable (Week 1)(含测试数据和源码)
  2. 使用Nginx的proxy_cache缓存功能取代Squid
  3. 实现java多线程的3种方式,99%人没用过第3种
  4. libevent源码学习-----统一事件源及信号绑定函数
  5. docker zookeeper kafka kafka-manager 本地hbase hadoop
  6. 初二模拟赛总结(2019.8.7)
  7. 计算机语言由低到高就被分为了什么阶段,2004年4月高等教育自学考试认知心理试题...
  8. mysql 创建索引 终止_技术分享 | 常见索引问题处理
  9. linux tlhelp32.h,CreateToolhelp32Snapshot
  10. 搭建局域网HTTP FTP服务
  11. windows10 右键 manage 没反应
  12. 淘宝生成器在线制作,淘宝全屏代码装修店招导航教程
  13. 【非标自动化】2017年的最NB的非标自动化内容都在这了
  14. 10的负2次方用计算机怎么算,2的负二次方等于多少(进制转换计算器)
  15. TI C64X+通用库函数使用手册
  16. Server responded “Algorithm negotiation failed“错误解决方法
  17. Android自定义消息推送
  18. Linux PostgreSQL离线下载与安装
  19. 本周内外盘行情回顾2022.3.6
  20. win10睡眠锁定计算机,Win10专业版电脑睡眠和休眠的区别是什么?

热门文章

  1. 怎么从pdf中提取图片?三招告诉你如何从pdf中提取图片
  2. 选择属于自己的一亩三分地
  3. 计算机算法对程序设计的作用,浅谈对计算机程序设计的认识
  4. 闭包 python_请问开集和闭集如何理解?
  5. 音视频开发入门基础知识(视频入门篇)
  6. 如何高效管理企业的海量固定资产?
  7. Massive MIMO与MU-MIMO的区别?
  8. java最难的部分_java最难学的是那一块?
  9. Deep Learning 最优化方法之RMSProp
  10. AutoCAD消息:无写入权限。无法创建 acad.cuix(南方测绘CASS11.0)