USACO 3.1 Agri-Net 最短网络 (最小生成树)(普里姆算法)
来源:互联网 发布:steam淘宝充值卡便宜 编辑:程序博客网 时间:2024/05/18 17:40
题意
农民约翰被选为他们镇的镇长!他其中一个竞选承诺就是在镇上建立起互联网,并连接到所有的农场。当然,他需要你的帮助。约翰已经给他的农场安排了一条高速的网络线路,他想把这条线路共享给其他农场。为了用最小的消费,他想铺设最短的光纤去连接所有的农场。你将得到一份各农场之间连接费用的列表,你必须找出能连接所有农场并所用光纤最短的方案。每两个农场间的距离不会超过100000
分析
这题我是用普里姆算法
一个一个点枚举,如果它小于min,并且它不等于0,那么min=这个点,记录下这个点
var
n,tj,i,j,k,x,y,t,min:longint;
a:array[0..200,0..200]of longint;
f:array[0..200]of longint;
begin
readln(n);
fillchar(a,sizeof(a),0);
fillchar(f,sizeof(f),0);
for i:=1 to n do
for j:=1 to n do
read(a[i,j]);
f[1]:=1;
tj:=0;
for i:=1 to n-1 do
begin
min:=maxlongint;
for j:=1 to n do
if f[j]=1 then
for k:=1 to n do
if f[k]=0 then
if (a[j,k]<min)and(a[j,k]<>0) then
begin
min:=a[j,k];
t:=k;
end;
if min<>maxint then
begin
tj:=tj+min;
f[t]:=1;
end;
end;
write(tj);
end.
- USACO 3.1 Agri-Net 最短网络 (最小生成树)(普里姆算法)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- [最小生成树]USACO 3.1 Agri-Net 最短网络
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1.1 Agri-Net 最短网络(最小生成树Prime算法)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)(克鲁斯卡尔算法)
- 【USACO】Agri-Net最短网络(最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)(改)
- SSL 1682——USACO 3.1 Agri-Net 最短网络 (最小生成树)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)-SSL 1682
- (ssl1682)P1546 USACO 3.1 Agri-Net 最短网络 (最小生成树)
- 【Redis】常用命令
- JavaScript算法练习
- 2017年华为实习生招聘笔试题2
- bzoj1645
- [编程题] 优雅的点
- USACO 3.1 Agri-Net 最短网络 (最小生成树)(普里姆算法)
- USACO 3.1 Agri-Net 最短网络 (最小生成树)
- L0,L1,L2
- Java线程(十一):Fork/Join-Java并行计算框架
- 多态(二)--例子
- Shell脚本问题详解
- poj 3264 Balanced Lineup(线段树)
- wget 命令用法详解
- 复杂链表的复制