数据结构实验之图论六:村村通公路
数据结构实验之图论六:村村通公路
Time Limit: 1000MS Memory limit: 65536K
题目描述
输入
输出
示例输入
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;
}
数据结构实验之图论六:村村通公路相关推荐
- SDUT-3362 数据结构实验之图论六:村村通公路
数据结构实验之图论六:村村通公路 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Discuss Problem Descripti ...
- 数据结构实验之图论六:村村通公路(最小生成树Prim/Kruskal)
Description 当前农村公路建设正如火如荼的展开,某乡镇政府决定实现村村通公路,工程师现有各个村落之间的原始道路统计数据表,表中列出了各村之间可以建设公路的若干条道路的成本,你的任务是根据给出 ...
- 数据结构实验之图论七:驴友计划(最新版)
数据结构实验之图论七:驴友计划 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 做为一个资深驴友,小新有一张珍藏的自驾游 ...
- 数据结构实验之图论九:最小生成树
数据结构实验之图论九:最小生成树 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 有n个城市,其中有些城市之间可以修建公 ...
- oj 数据结构实验之图论三:判断可达性
数据结构实验之图论三:判断可达性 Description 在古老的魔兽传说中,有两个军团,一个叫天灾,一个叫近卫.在他们所在的地域,有n个隘口,编号为1-n,某些隘口之间是有通道连接的.其中近卫军团在 ...
- SDUT_2121数据结构实验之链表六:有序链表的建立 (对建立的单项链表结构进行排序)
点击打开链接 数据结构实验之链表六:有序链表的建立 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Discuss Problem ...
- SDUT-3378_数据结构实验之查找六:顺序查找
数据结构实验之查找六:顺序查找 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 在一个给定的无序序列里,查找与给定关键字 ...
- 山东理工OJ【2121】数据结构实验之链表六:有序链表的建立(插排法)
数据结构实验之链表六:有序链表的建立 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 输入N个无序的整数,建立一个有序链表, ...
- SDUT-2121_数据结构实验之链表六:有序链表的建立
数据结构实验之链表六:有序链表的建立 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 输入N个无序的整数,建立一个有序链 ...
最新文章
- deno使用rust_如何在Deno和Oak中使用MySQL
- 史上最全 Java 多线程面试题及答案
- 使用JConsole监控ActiveMQ
- 在5G时代,微信还能活多久?
- 中南大学计算机网络期末试卷,中南大学计算机网络期末复习试卷1
- Python中stack(),vstack(),hstack()的用法和区别
- Qt开发植物大战僵尸第一篇
- 软件测试 - Linux和数据库
- mysql sniffer数据库审计_MySQL抓包工具:MySQL Sniffer
- 运维工程师绩效考核表_IT运维绩效考核表
- 上位机软件系统开发工具简介
- HCL配置不同VLAN之间进行通讯实验
- GC overhead limit exceeded问题
- matlab梯形法数值积分,数值积分(梯形法)
- 什么是点对点?什么去中心化?
- 假设某台式计算机的内存容量为256,计算机二级试题与答案
- 吴恩达机器学习神经网络 8-1非线性假设
- 6个实用的红米手机技巧
- 光猫、光纤收发器、路由器、交换机
- SpringSecurity学习笔记(三)自定义资源拦截规则以及登录界面跳转
热门文章
- 编写高性能 Java 代码的最佳实践
- 在C ++中将十进制转换为二进制
- 深度学习在计算机视觉领域(图像,视频,3D点云,深度图等)应用全览
- 软件工程概念总结-期末重点-(说人话版 简单中文+英文关键词)-拆书-第二部分建模(原书第7-11章)-罗杰S普莱斯曼
- 页面展开收起php代码,纯CSS3实现移动端展开和收起效果的示例代码
- Java实践(一)之击船游戏
- 靠手表“上位”的儿童社交,“红眼”微信做儿童版就有机会了吗?
- excel表格中插入图片(使用table公式)
- 视觉算法工程师面试总结[2022春季 达摩院 美团 字节 华为]
- PHP阿里云短信发送文件(带签名)