#include "stdlib.h"
#include "stdio.h"
#define MAX 100
#define M (MAX*(MAX-1)/2)
/*
Test data:
6 0 1 1 0 2 33 0 3 43 0 4 5 0 5 32 1 2 3 1 3 4 1 4 5 1 5 76 2 3 2 2 4 5 2 5 6 3 4 5 3 5 665 4 5 4 -1 -1 -1
result:
(V0 ,V1 )(V2 ,V3 )(V1 ,V2 )(V4 ,V5 )(V0 ,V4 )
The sum is:15
*/
/*每次从边中选取最小边,直到领点都选取完,并输出T的各条边及各条边的权之和*/
/*无向图带权结构体*/
typedef struct
{
int i,j,w;
}Edge;
/*按 权 排序*/
void bsort(Edge a[],int n)
{
Edge t;
int i,j,ok;
for(i=1;i<n;i++)
{
ok=1;
for(j=0;j<n-i;j++)
if(a[j].w>a[j+1].w)
{
t=a[j];
a[j]=a[j+1];
a[j+1]=t;
ok=0;
}
if(ok)break;
}
}
/*读入权信息*/
void read(Edge a[],int *c,int n)
{
int i,j,w;
*c=0;
do
{
scanf("%d%d%d",&i,&j,&w);
if(i==-1||j==-1||w==-1)break;
if(i<0||i>=n||j<0||j>=n||w<=0||i==j) continue;
if(*c>=M)
{
exit(-2);
}
a[*c].i=i;a[*c].j=j;a[*c].w=w;(*c)++;
}while(9);
}
/*sameTree链表功能 表示两个顶点是否在一棵树下,初始化为-1,*/
int sameTree[MAX];
int inSameTree(int i,int j)
{
int s;
if(sameTree[i]==-1)
{
if(sameTree[j]==-1)
{
sameTree[i]=j;
sameTree[j]=i;
}
else
{
sameTree[i]=sameTree[j];
sameTree[j]=i;
}
return 0;
}
else
{
if(sameTree[j]==-1)
{
sameTree[j]=sameTree[i];
sameTree[i]=j;
return 0;
}
else
{
s=i;
//循环判定该两点的边
while(sameTree[s]!=i)
{
if(sameTree[s]==j)return 1;
s=sameTree[s];
}
//如果i j存在 没有连通
sameTree[s]=sameTree[j];
sameTree[j]=i;
return 0;
}
}
}
void MST(Edge a[],int n,int vnum)
{
int c=0,i,sum=0;
//从n条边中选取vnum-1条边
for(i=0;i<n;i++)
{
if(inSameTree(a[i].i,a[i].j))continue;
sum+=a[i].w;
printf("(V%-2d,V%-2d)",a[i].i,a[i].j);
if(++c%8==0)printf("\n");
if(c>=vnum-1)
{
printf("\nThe sum is:%d\n",sum);
return;
}
}
if(c<vnum-1)printf("\nThe graph is not connect\n");
}
void main()
{
Edge a[M];
int i,n,vnum;//n边数 vnum顶点个数
printf("enter verxnum and edges with weight:\n");
scanf("%d",&vnum);
if(vnum<1||vnum>MAX)
{
printf("error:vnum mun must be in [1..%d]\n",MAX);
return;
}
read(a,&n,vnum);
bsort(a,n);
for(i=0;i<vnum;i++)
{
sameTree[i]=-1;
}
MST(a,n,vnum);
}
分享到:
相关推荐
《克鲁斯卡尔法求最小生成树》 在图论领域,寻找最小生成树是解决网络连接问题的一个重要算法。最小生成树问题旨在找到一个无向加权图的边子集,这些边连接了所有顶点,且总权重尽可能小。克鲁斯卡尔(Kruskal)...
克鲁斯卡尔算法(Kruskal's Algorithm)是求解最小生成树的一种经典方法,由约瑟夫·克鲁斯卡尔在1956年提出。本项目以Java编程语言实现了这一算法,并结合图形界面,使得理解和应用更加直观。 首先,我们要理解...
卡尔法奇(Carlfudge)在IT领域中可能是指一种特定的技术、工具或者是一个开发者的名字。由于提供的信息有限,我会假设“卡尔法奇”与CSS(层叠样式表)有关,因为标签指明了这个主题。CSS是网页设计中用于控制布局...
2. **动力学模型**:模型会包含描述机器人运动的数学方程,如牛顿-欧拉或迪卡尔法。这些方程会考虑到重力、惯性、摩擦和关节驱动力等因素。 3. **控制器模块**:可能有一个简单的PID控制器或者更复杂的控制策略,...
图形化a+b,可以锻炼你的记忆力和算数速度
柔性输送线sw18可编辑全套技术资料100%好用.zip
本汽车票网上预订系统管理员和用户。管理员功能有个人中心,用户管理,汽车票管理,订单管理,退票管理,换票管理,反馈管理,留言板管理,系统管理等。用户功能有个人中心,汽车票管理,订单管理,退票管理,换票管理,反馈管理等。 内含文档,可轻松上手。
自动锁螺丝机细化完全step全套技术资料100%好用.zip
【创新无忧】基于matlab龙格库塔算法RUN优化极限学习机KELM故障诊断【含Matlab源码 10715期】.zip
pll电荷泵锁相环 cppll(已流片)仿真环境搭建好了 电路到版图都已流片验证,另外送PLL书籍电子版和对应工艺库。 另加50就可以得到完整版图 三阶二型锁相环 参考频率50-100MHz 分频比可调 锁定频率600M-2GHz 锁定时间4us 环形振荡器 ring vco 鉴频鉴相器PFD模块 分频器DIV模块 ,ps counter 电荷泵CP模块
智慧社区有管理员和客户两个角色。客户功能有车位信息,社区信息,周边服务,问卷调查,爱心助老,通知公告,留言反馈,个人中心,客服中心,在线报修管理,投诉建议管理,车位租买管理,社区信息管理,参与答卷管理,我的收藏管理。管理员功能有个人中心,客户管理,在线报修管理,投诉建议管理,车位信息管理,车位租买管理,社区信息管理,周边服务管理,问卷调查管理,参与答卷管理,爱心助老管理,留言板管理,系统管理。 内含文档,可轻松上手。
本科生课程设计封面.doc
展示PRD文档的关键要素编写具体示例。同时提供了一份模板,方便撰写PRD文档。
基于matlab的用于分析弧齿锥齿轮啮合轨迹的程序,输出齿轮啮合轨迹及传递误差。 程序已调通,可直接运行。 程序保证可直接运行。
【创新无忧】基于matlab向量加权平均算法INFO优化极限学习机KELM故障诊断【含Matlab源码 10732期】.zip
仓库管理系统(一个毕设) 毕业设计项目《仓库管理系统(manager_sys)》的概述和指南: 项目标题 《基于Spring MVC和Vue.js的仓库管理系统设计与实现 —— 毕业设计项目》 项目概述 本项目是一个基于Spring MVC、Spring Security、Spring、MyBatis、PageHelper和Vue.js框架的仓库管理系统。系统旨在提供高效、安全的库存管理解决方案,包括权限管理、商品管理、订单处理和库存预警等功能。 系统特点 权限管理:利用Spring Security实现基于角色的访问控制(RBAC),动态分配权限。 业务流程:涵盖商品、订单、库存的完整操作流程,确保库存管理的准确性。 日志记录:通过Spring AOP实现操作日志的记录,便于追踪和审计。 数据统计:首页展示商品销量统计图和每日销售统计图,直观展示业务状况。 系统预览 登录和首页:用户登录后进入系统首页,查看统计信息。 产品管理:管理商品信息,包括添加、修改、删除等操作。 订单管理:处理订单,包括创建订单、更新库存等。 权限管理:管理用户角色和权限。 日志管理:查看系统操作日志。 运
A星算法 A*算法 自己研究编写的Matlab路径规划算法 Astar算法走迷宫 可自行设置起始点,目标点,自由更地图。 ——————————————————— 可以和人工势场法融合 动态障碍物
《MATLAB神经网络原理与实例精解》是一本深度学习初学者的理想教程,它全面涵盖了神经网络的基础理论以及MATLAB实现方法。这本书旨在帮助读者理解神经网络的工作原理,并通过具体的MATLAB实例,让读者能够动手实践,从而深入掌握神经网络在实际问题中的应用。 神经网络是一种模仿人脑神经元结构的计算模型,它由大量的处理单元——神经元组成,通过权重连接形成复杂的网络结构。在深度学习领域,神经网络被广泛用于图像识别、语音识别、自然语言处理等任务,因其强大的非线性建模能力而备受青睐。 MATLAB作为一个强大的数值计算和数据可视化环境,为构建和训练神经网络提供了便利的工具箱。MATLAB神经网络工具箱(Neural Network Toolbox)包含了各种类型的神经网络模型,如前馈网络、卷积网络、递归网络等,以及训练算法,如反向传播、遗传算法等。通过这些工具,用户可以快速构建网络结构,调整参数,进行训练和验证,并将模型应用于实际数据。 本书首先会介绍神经网络的基本概念,包括感知机、多层前馈网络和反向传播算法。然后,将详细讲解如何在MATLAB中搭建这些网络,包括网络结构的设计、权重初始
Matlab领域上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
ABAQUS动,静力学模型;车辆-轨道耦合动力学;钢轨不平顺程序;批量非线性弹簧;单向弹簧(收拉不受压或受压不受拉),温度耦合等。 轨道检算(超高,超限,出报告);土木建筑有限元建模分析。