POJ3723-Conscription

将男女之间的关系看作一条边,想要费用最少就是找出一个最小生成树。

将边从小到大排序后,利用并查集将未连结的两点相连,便是最小生成树。

由于费用减免只能用于一人,我们将两人之间的费用减免(-d)作为边的权值。

求出最小生成树后将所有人的费用减去最大的所有的费用减免即是最小的费用。

#include <cstdio>
#include <algorithm>

using namespace std;

const int maxn = 20000 + 10;
const int maxr = 50000 + 10;

int par[maxn];
int ran[maxn];

void init(int n)
{
    for (int i = 0; i <= n; i++) {
        par[i] = i;
        ran[i] = 0;
    }
}

int find(int x)
{
    if (par[x] == x) {
        return x;
    }
    else {
        return par[x] = find(par[x]);
    }
}

void unite(int x, int y)
{
    x = find(x);
    y = find(y);
    if (x == y) {
        return;
    }
    
    if (ran[x] < ran[y]) {
        par[x] = y;
    }
    else {
        par[y] = x;
        if (ran[x] == ran[y]) {
            ran[x]++;
        }
    }
}

bool same(int x, int y)
{
    return find(x) == find(y);
}

struct edge
{
    int u, v, cost;
    
    bool operator < (const edge& e) const {
        return cost < e.cost;
    }
};

edge es[maxr];

int Kruskal(int v, int e)
{
    sort(es, es + e);
    init(v);
    int res = 0;
    for (int i = 0; i < e; i++) {
        edge ed = es[i];
        if (!same(ed.u, ed.v)) {
            unite(ed.u, ed.v);
            res += ed.cost;
        }
    }
    return  res;
}

int main()
{
    int t;
    scanf("%d", &t);
    
    while (t--) {
        int n, m, r;
        scanf("%d%d%d", &n, &m, &r);
        for (int i = 0; i < r; i++) {
            int x, y, d;
            scanf("%d%d%d", &x, &y, &d);
            es[i] = {x, n + y, -d};
        }
        printf("%d\n", 10000 * (n + m) + Kruskal(n + m, r));
    }
    
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
旋转变压器---数字转换器作为现代伺服系统中被广泛使用的角位置测量系统,大量应用于高精度及大中型数控系统、机器人控制、工业控制、武器火力控制及惯性导航领域中。 传统的角测量系统面临的问题有:体积、重量、功耗偏大,调试、误差补偿试验复杂,费用较高。本文从微型化、智能化的方向进行研究,是解决传统角测量系统所面临问题的好途径。 本文所研究的旋转变压器---数字转换器是由信号调理模块、系统芯片C8051F064和输出控制模块组成的。整个系统的三路输入信号为X=AsinOcosar、Y=Acosθcos ot和Z=Ucosar(基准信号),输出信号为偏转角θ,输出形式为16 位数字量。信号调理模块是由模拟电路组成的,包括信号输入电路、相敏整流电路、滤波电路和直流稳压电源电路,其难点在于相敏整流电路的设计。信号调理模块的主要功能是把输入的交流信号X=AsinOcosor、Y=Acosθcosot转变成直流信号Bsinθ和Bcosθ,并使输出的直流信号在0~2.4V之间;系统芯片C8051F064是CYGNAL公司近年来推出的一款功能齐全的完全集成的混合信号片上系统型单片机。在本文所设计的系统中,系统芯片的输入信号为直流信号Bsinθ和Bcosθ,通过片内自带的2个16位A/D转换器对输入信号的数据进行采样和转换,并对转换完的数据进行滤波处理,以减小由于外界干扰而产生的误差,再用除法和反正切函数解算出偏转角θ的16位数字量;输出控制模块主要完成的功能是通过UARTO向计算机实时发送由单片机计算出来的偏转角度0的16位数字量,而串口的RS-232电平与单片机系统采用的是TTL电平之间的转换所采用的转换芯片是MC1488和MC1489。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值