(次小生成树/思维)Qin Shi Huang's National Road System

探讨了如何通过计算最小生成树解决秦始皇连接n个城市的问题,以找到最优的无消耗道路建设方案,同时确保其他道路成本最小。算法采用Prim算法计算最小生成树,并通过枚举和次小生成树计算最优解。

http://acm.hdu.edu.cn/showproblem.php?pid=4081

题意为秦始皇需要建立一个n-1条路来连接n个城市,在这n-1条边中可以无消耗建立一条边,满足(该边连接的城市人口和/其他n-2条边距离和)最大,且其他n-2条边的距离尽可能小
首先算出该图的最小生成树mst,对于这条特殊的边,枚举每条边,若该边在最小生成树里,答案即是人口/mst-该边权值;若不在mst中,将其加入mst后删掉环中最长边(即求次小生成树),即是人口/mst-最长边。

#include <iostream>
#include <algorithm>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <vector>
#include <string>
#include <queue>
#include <cmath>
using namespace std;
const int maxn = 1004;
struct node {
    int x, y, p;
} a[maxn];
int t, n, vis[maxn], pre[maxn], used[maxn][maxn];
double dis[maxn][maxn], f[maxn][maxn], dist[maxn], mst = 0;
void prim() {
    mst = 0;
    memset(vis, 0, sizeof(vis));
    memset(used, 0, sizeof(used));
    memset(f, 0, sizeof(f));
    vis[1] = 1;
    for(int i = 2; i <= n; i++) dist[i] = dis[1][i], pre[i] = 1;
    for(int i = 1; i < n; i++) {
        double tmp = 0x3f3f3f3f * 1.0;
        int to;
        for(int j = 1; j <= n; j++) if(!vis[j]) {
            if(tmp > dist[j]) {
                tmp = dist[j];
                to = j;
            }
        }
        vis[to] = 1;
        mst += tmp;
        used[pre[to]][to] = used[to][pre[to]] = 1;
        for(int j = 1; j <= n; j++) {
            if(vis[j] && j != to) f[to][j] = f[j][to] = max(f[pre[to]][j], tmp);
            if(!vis[j]) {
                if(dist[j] > dis[to][j]) {
                    pre[j] = to;
                    dist[j] = dis[to][j];
                }
            }
        }
    }
}
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.precision(2);
    cout << fixed;
    cin >> t;
    while(t--) {
        cin >> n;
        for(int i = 1; i <= n; i++) {
            cin >> a[i].x >> a[i].y >> a[i].p;
            for(int j = 1; j < i; j++) {
                dis[i][j] = dis[j][i] = sqrt((a[i].x - a[j].x) * (a[i].x - a[j].x) + (a[i].y - a[j].y) * (a[i].y - a[j].y));
            }
        }
        prim();
        double ans = 0;
        for(int i = 1; i <= n; i++) {
            for(int j = 1; j < i; j++) {
                if(used[i][j]) ans = max(ans, (a[i].p + a[j].p) / (mst - dis[i][j]));
                else ans = max(ans, (a[i].p + a[j].p) / (mst - f[i][j]));
            }
        }
        cout << ans << endl;
    }
}
## 01、数据介绍 数据整理全国30个省份制造业细分行业产值,能够反映一定时期内细分行业工业生产总规模和总水平的指标,是计算工业生产发展速度和主要比例关系、计算工业产品销售率等其他经济指标的基础。先进制造业数据可用于两业融合测算。 数据名称:全国30省-制造业细分行业产值/先进制造业细分行业产值数据 数据年份:2001-2022年 ## 02、数据指标 农副食品加工业;食品制造业;饮料制造业;烟草制造业;纺织业;纺织服装鞋帽制造业;皮革、毛皮、羽毛(绒)极其制品业;木材加工及木、竹、藤、棕、草制品业;家具制造业;造纸及纸制品业;印刷业和记录媒介的复制;文教体育用品制造业;石油加工、炼焦及核燃料加工业化;学原料及化学制品制造业;医药制造业;化学纤维制造业;橡胶和塑料制品制品业;非金属矿物制品业;黑色金属冶炼及压延加工业;有色金属冶炼及压延加工业;金属制品业;通用设备制造业;专用设备制造业;汽车制造业;其他运输设备制造业;电气机械及器材制造业;通信设备计算机及其他电子设备制造业;仪器仪表及文化、办公用机械制造业;其他制造业;废弃资源和废旧材料回收加工业;制造业总产值 印刷业和记录媒介的复制;石油加工、炼焦及核燃料加工业;化学原料及化学制品制造业;医药制造业;橡胶和塑料制品制品业;非金属矿物制品业;黑色金属冶炼及压延加工业;有色金属冶炼及压延加工业;金属制品业;通用设备制造业;专用设备制造业;汽车制造业;其他运输设备制造业;电气机械及器材制造业;通信设备计算机及其他电子设备制造业;仪器仪表及文化、办公用机械制造业;废弃资源和废旧材料回收加工业
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值