LOJ10066
LOJ10066 新的开始
题目描述
发展采矿业当然首先得有矿井,小 F 花了上次探险获得的千分之一的财富请人在岛上挖了 n 口矿井,但他似乎忘记考虑的矿井供电问题……
为了保证电力的供应,小 F 想到了两种办法:
- 在这一口矿井上建立一个发电站,费用为 v(发电站的输出功率可以供给任意多个矿井)。
- 将这口矿井与另外的已经有电力供应的矿井之间建立电网,费用为 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的更多相关文章
- LOJ10066 新的开始
LOJ10066 新的开始 prim 典型题.碰到这种情况,只要建一个虚拟节点,和其他的点连边,按题目给权值即可 代码中把n+1当成虚拟节点 懒得写kruskal就用prim了 #include< ...
随机推荐
- 在搜索引擎中输入汉字就可以解析到对应的域名,请问如何用LoadRunner进行测试。
建立测试计划,确定测试标准和测试范围 设计典型场景的测试用例,覆盖常用业务流程和不常用的业务流程等 根据测试用例,开发自动测试脚本和场景: 录制测试脚本:新建一个脚本(Web/HTML协议):点 ...
- Vue 面试题总结
1. Vue 框架的优点是什么? (1)轻量级框架:只关注视图层,大小只有几十Kb: (2)简单易学:文档通顺清晰,语法简单: (3)数据双向绑定,数据视图结构分离,仅需操作数据即可完 ...
- lambda表达式初识
简单来说,一般提到的 lambda 表达式,通常是在需要一个函数,但是又不想费神去命名一个函数的场合下使用,也就是指匿名函数. 而匿名函数就是没有名字的函数,有时函数只是临时一用,而且它的业务逻辑也相 ...
- UNION An Unreferenced Metric for Evaluating Open-ended Story Generation精读
UNION An Unreferenced Metric for Evaluating Open-ended Story Generation精读 UNION: 一种评估开放故事生成无参考文本依赖me ...
- 今天写了一个SSM小项目,运行之后,前端页面的CSS、js样式显示不出来,具体操作如下:
因为SSM中我们设置了拦截器,拦截器会拦截CSS和JS,所有样式渲染不出来,在Web.xml中写上 1 <servlet-mapping> 2 <servlet-name>de ...
- chatsRoom Design Report
基于TCP实现聊天室 主要使用四个类 ChatClient类 使用BufferedReader 得到输入流,使用OutputStream得到输出流 实现读取服务器广播的消息和发送消息到 ...
- [Leetcode刷题]——链表
一.找出两个链表的交点 160.相交链表(easy)2021-01-05 编写一个程序,找到两个单链表相交的起始节点 如下面的两个链表,在c1 处相交: public class Soluti ...
- idea生成UML
原文链接http://zhhll.icu/2020/12/18/idea/%E7%94%9F%E6%88%90UML/ 使用idea直接生成UML类图 然后点击所要生成的类即可生成 由于本身的博客百度 ...
- 【C++】《Effective C++》第五章
第五章 实现 条款26:尽可能延后变量定义式的出现时间 只要定义了一个变量而其类型带有一个构造函数或析构函数,那么 当程序的控制流到达这个变量定义式时,你得承受这个构造成本. 当这个变量离开这个作用域 ...
- 如何实现CentOS服务器的扩容??
Linux的硬盘识别: 一般使用"fdisk -l"命令可以列出系统中当前连接的硬盘 设备和分区信息.新硬盘没有分区信息,则只显示硬盘大小信息. 1.关闭服务器加上新硬盘 2.启动 ...