LOJ10066 新的开始

题目描述

发展采矿业当然首先得有矿井,小 F 花了上次探险获得的千分之一的财富请人在岛上挖了 n 口矿井,但他似乎忘记考虑的矿井供电问题……

为了保证电力的供应,小 F 想到了两种办法:

  1. 在这一口矿井上建立一个发电站,费用为 v(发电站的输出功率可以供给任意多个矿井)。
  2. 将这口矿井与另外的已经有电力供应的矿井之间建立电网,费用为 p。

小 FF 希望身为「NewBe_One」计划首席工程师的你帮他想出一个保证所有矿井电力供应的最小花费。

输入格式

第一行一个整数 n,表示矿井总数。

第 2∼n+1 行,每行一个整数,第 i 个数vi​ 表示在第i 口矿井上建立发电站的费用。

接下来为一个n×n 的矩阵 pp,其中pi,j​ 表示在第 i 口矿井和第 j 口矿井之间建立电网的费用(数据保证有pi,j​=pj,i​,且 pi,i​=0)。

输出格式

输出仅一个整数,表示让所有矿井获得充足电能的最小花费。

样例

样例输入

4
5
4
4
3
0 2 2 2
2 0 3 3
2 3 0 4
2 3 4 0

样例输出

9

样例解释

小 FF 可以选择在 4 号矿井建立发电站然后把所有矿井都不其建立电网,总花费是3+2+2+2=9。

数据范围与提示

对于 30% 的数据:1≤n≤50;
对于 100% 的数据:1≤n≤300,0≤vi​,pi,j​≤10^5。

_______________________________________________________

最小生成树,记得建立0号点,把0号点到其他点的边长设为建电站的花费。

_______________________________________________________

 1 #include<bits/stdc++.h>
2 using namespace std;
3 const int maxn=305;
4 struct edge
5 {
6 int u,v,w;
7 }e[maxn*maxn];
8 int n,js,cnt;
9 long long ans;
10 void addage(int u,int v,int w)
11 {
12 e[js].u=u;e[js].v=v;e[js++].w=w;
13 }
14 bool mycmp(edge a,edge b)
15 {
16 return a.w<b.w;
17 }
18 int fa[maxn];
19 int find(int x)
20 {
21 if(x==fa[x])return x;
22 return fa[x]=find(fa[x]);
23 }
24 int main()
25 {
26 scanf("%d",&n);
27 for(int x,i=1;i<=n;++i)
28 {
29 scanf("%d",&x);
30 addage(0,i,x);
31 }
32 for(int x,i=1;i<=n;++i)
33 {
34 for(int j=1;j<=n;++j)
35 {
36 scanf("%d",&x);
37 if(i<j)addage(i,j,x);
38 }
39 }
40 for(int i=0;i<=n;++i)fa[i]=i;
41 sort(e,e+js,mycmp);
42 for(int i=0;i<js;++i)
43 {
44 int a=find(e[i].u),b=find(e[i].v);
45 if(a!=b)
46 {
47 fa[a]=b;
48 ans+=e[i].w;
49 ++cnt;
50 if(cnt==n)break;
51 }
52 }
53 cout<<ans;
54 return 0;
55 }

LOJ10066的更多相关文章

  1. LOJ10066 新的开始

    LOJ10066 新的开始 prim 典型题.碰到这种情况,只要建一个虚拟节点,和其他的点连边,按题目给权值即可 代码中把n+1当成虚拟节点 懒得写kruskal就用prim了 #include< ...

随机推荐

  1. [leetcode712] Minimum ASCII Delete Sum for Two Strings

    public int minimumDeleteSum(String s1, String s2) { /* 标准的动态规划题目,难点在于想出将两个字符串删除到相同的过程 这里从两个字符串的开头字符考 ...

  2. WebSocket入门及使用指南

    最近在一个项目中,需要使用到websocket,于是就花了一点时间来熟悉websocket并总结写篇blog. 为何使用websocket 在浏览器与服务器通信间,传统的 HTTP 请求在某些场景下并 ...

  3. erlang开发环境(IDE)搭建

    1.首先推荐:intellij idea http://www.open-open.com/news/view/44c90e 2.webstorm: http://plugins.jetbrains. ...

  4. 基于Python的接口自动化实战-基础篇之pymysql模块操作数据库

    引言 在进行功能或者接口测试时常常需要通过连接数据库,操作和查看相关的数据表数据,用于构建测试数据.核对功能.验证数据一致性,接口的数据库操作是否正确等.因此,在进行接口自动化测试时,我们一样绕不开接 ...

  5. 深入理解Kafka必知必会(1)

    Kafka的用途有哪些?使用场景如何? 消息系统: Kafka 和传统的消息系统(也称作消息中间件)都具备系统解耦.冗余存储.流量削峰.缓冲.异步通信.扩展性.可恢复性等功能.与此同时,Kafka 还 ...

  6. JAVA_基础反射机制

    Java反射机制概述 Reflection(反射)是被视为动态语言的关键,反射机制允许程序在执行期 借助于Reflection API取得任何类的内部信息,并能直接操作任意对象的内 部属性及方法. 加 ...

  7. [新手教程]申请https泛域名解析

    前置准备 教程开始,我们默认相信小伙伴们对基本的域名购买及解析有了一定的认识和实践 一个正常的域名 一台公网服务器 域名解析操作 如:现在我们要设置frps的泛域名解析 设置二级域名 frp.xx.c ...

  8. Zero date value prohibited解决方法

    发现错误 在做新需求时,建了新表,但是在测试debug中,控制台报了java.sql.SQLException: Zero date value prohibited错误 数据库用的是Date类型 实 ...

  9. 使用 Admission Webhook 机制实现多集群资源配额控制

    1 要解决的问题 集群分配给多个用户使用时,需要使用配额以限制用户的资源使用,包括 CPU 核数.内存大小.GPU 卡数等,以防止资源被某些用户耗尽,造成不公平的资源分配. 大多数情况下,集群原生的 ...

  10. Head First 设计模式 —— 11. 组合 (Composite) 模式

    思考题 我们不仅仅要支持多个菜单,升值还要支持菜单中的菜单.你如何处理这个新的设计需求? P355 [提示]在我们的新设计中,真正需要以下三点: P354 我们需要某种属性结构,可以容纳菜单.子菜单和 ...