2021-08-10校网比赛B题

本文介绍了一种解决最小生成树问题的方法——Kruskal算法,通过建立超级源点并进行边的排序,逐步连接节点,直至形成一棵最小生成树。在实现过程中需要注意避免超时和正确存储边。代码示例展示了如何应用Kruskal算法来找到最小的雇佣和交流费用总和。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
在这里插入图片描述

思路:
建立一个超级源点S,
S向所有人连边,边权为雇佣费用
人与人之间存在连边,即交流费用
求最小生成树即可
注意几个细节:

  1. 对于最小生成树的边存储只能存一半,否则会超时。
  2. 千万不要打快读,我也不知道为什么比赛几个打快读的都炸掉了
#include <cstdio>
#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;

//typedef long long int;

const int N = 1e6 + 10;
const int M = 1e3 + 10;
struct node {int u, v, w;} e[N];
int n, cnt, ans, t, f[N], a, tot;

bool cmp(node a, node b) {return a.w < b.w;}

int find(int x) {return (x == f[x]) ? x : (f[x] = find(f[x]));}

void unionn(int x, int y, int w) {f[x] = y; ans += w; tot++;}

int main()
{
	scanf("%d", &n);
	for(int i = 1; i <= n; i++)
	 for(int j = 1; j <= n; j++)
	 {
	 	scanf("%d", &t);
		if(i < j) e[++cnt] = (node){i, j, t};	
	 }
	for(int i = 1; i <= n; i++) 
		scanf("%d", &a), f[i] = i, e[++cnt] = (node){0, i, a};
	sort(e + 1, e + 1 + cnt, cmp);
	for(int i = 1; i <= cnt; i++)
	{
		int u = e[i].u, v = e[i].v;
		int fx = find(u), fy = find(v);
		if(fx != fy) unionn(fx, fy, e[i].w);
		if(tot == n) break;
	}
	printf("%d\n", ans);
	return 0;
} 
内容概要:本文详细介绍了施耐德M580系列PLC的存储结构、系统硬件架构、上电写入程序及CPU冗余特性。在存储结构方面,涵盖拓扑寻址、Device DDT远程寻址以及寄存器寻址三种方式,详细解释了不同类型的寻址方法及其应用场景。系统硬件架构部分,阐述了最小系统的构建要素,包括CPU、机架和模块的选择与配置,并介绍了常见的系统拓扑结构,如简单的机架间拓扑和远程子站以太网菊花链等。上电写入程序环节,说明了通过USB和以太网两种接口进行程序下载的具体步骤,特别是针对初次下载时IP地址的设置方法。最后,CPU冗余部分重点描述了热备功能的实现机制,包括IP通讯地址配置和热备拓扑结构。 适合人群:从事工业自动化领域工作的技术人员,特别是对PLC编程及系统集成有一定了解的工程师。 使用场景及目标:①帮助工程师理解施耐德M580系列PLC的寻址机制,以便更好地进行模块配置和编程;②指导工程师完成最小系统的搭建,优化系统拓扑结构的设计;③提供详细的上电写入程序指南,确保程序下载顺利进行;④解释CPU冗余的实现方式,提高系统的稳定性和可靠性。 其他说明:文中还涉及一些特殊模块的功能介绍,如定时器事件和Modbus串口通讯模块,这些内容有助于用户深入了解M580系列PLC的高级应用。此外,附录部分提供了远程子站和热备冗余系统的实物图片,便于用户直观理解相关概念。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值