poj   1251  Jungle Roads  (最小生成树)

Link: http://poj.org/problem?id=1251

Jungle Roads

Time Limit: 1000MS

 

Memory Limit: 10000K

Total Submissions: 23507

 

Accepted: 11012

Description

The Head Elder of the tropical island of Lagrishan has a problem. A burst of
foreign aid money was spent on extra roads between villages some years ago. But
the jungle overtakes roads relentlessly, so the large road network is too
expensive to maintain. The Council of Elders must choose to stop maintaining
some roads. The map above on the left shows all the roads in use now and the
cost in aacms per month to maintain them. Of course there needs to be some way
to get between all the villages on maintained roads, even if the route is not
as short as before. The Chief Elder would like to tell the Council of Elders
what would be the smallest amount they could spend in aacms per month to
maintain roads that would connect all the villages. The villages are labeled A
through I in the maps above. The map on the right shows the roads that could be
maintained most cheaply, for 216 aacms per month. Your task is to write a
program that will solve such problems.

Input

The input consists of one to 100 data sets,
followed by a final line containing only 0. Each data set starts with a line
containing only a number n, which is the number of villages, 1 < n < 27,
and the villages are labeled with the first n letters of the alphabet,
capitalized. Each data set is completed with n-1 lines that start with village
labels in alphabetical order. There is no line for the last village. Each line
for a village starts with the village label followed by a number, k, of roads
from this village to villages with labels later in the alphabet. If k is
greater than 0, the line continues with data for each of the k roads. The data
for each road is the village label for the other end of the road followed by
the monthly maintenance cost in aacms for the road. Maintenance costs will be
positive integers less than 100. All data fields in the row are separated by
single blanks. The road network will always allow travel between all the
villages. The network will never have more than 75 roads. No village will have
more than 15 roads going to other villages (before or after in the alphabet). In
the sample input below, the first data set goes with the map above.

Output

The output is one integer per line for each
data set: the minimum cost in aacms per month to maintain a road system that
connect all the villages. Caution: A brute force solution that examines every
possible set of roads will not finish within the one minute time limit.

Sample Input

9

A 2 B 12 I 25

B 3 C 10 H 40 I 8

C 2 D 18 G 55

D 1 E 44

E 2 F 60 G 38

F 0

G 1 H 35

H 1 I 35

3

A 2 B 10 C 40

B 1 C 20

0

Sample Output

216

30

Source

Mid-Central USA 2002

题意:

给定多个点,和点与点之间的距离, 求最小让其连接起来的线路的总和。

经典的最小生成树问题。 使用 prime算法。

prime算法:

隔离出已经访问的点和未访问的点,寻找到访问过的点的树中到未访问点的最小距离,收之,
生成一个树, 继续。

// 1251
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std;
const int maxn = 30; int n, mp[maxn][maxn]; int Prime(int cur){
int i,j, minlen, sum, pt = cur, dist[maxn];
bool visited[maxn];
memset(visited, false, sizeof(visited));
visited[cur] = true;
sum = 0;
for(i=0; i<n; i++){
dist[i] = mp[cur][i];
}
for(i=1; i<n; i++){
minlen = 0x3f3f3f3f;
for(j=0; j<n; j++){
if(!visited[j] && minlen > dist[j]){
minlen = dist[j];
pt = j;
}
}
visited[pt] = true;
sum += minlen;
for(j=0; j<n; j++){
if(!visited[j] && dist[j] > mp[pt][j]){
dist[j] = mp[pt][j];
}
}
}
return sum;
} int main(){
freopen("in.txt", "r", stdin); int i,j, num2, num1, ans;
char ch1, ch2;
while(cin>>n && n){
memset(mp, 0x3f3f3f3f, sizeof(mp));
for(i=1; i<n; i++){
cin>>ch1>>num1;
for(j=1; j<=num1; j++){
cin>>ch2>>num2;
mp[ch1-'A'][ch2-'A'] = mp[ch2-'A'][ch1-'A'] = num2;
}
}
ans = Prime(ch1-'A');
cout<<ans<<endl;
}
return 0;
}

 

poj 1251 Jungle Roads (最小生成树)的更多相关文章

  1. POJ 1251 Jungle Roads - C语言 - Kruskal算法

    Description The Head Elder of the tropical island of Lagrishan has a problem. A burst of foreign aid ...

  2. POJ 1251 Jungle Roads(最小生成树)

    题意  有n个村子  输入n  然后n-1行先输入村子的序号和与该村子相连的村子数t  后面依次输入t组s和tt s为村子序号 tt为与当前村子的距离  求链接全部村子的最短路径 还是裸的最小生成树咯 ...

  3. POJ 1251 Jungle Roads (prim)

    D - Jungle Roads Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u Su ...

  4. POJ 1251 Jungle Roads (最小生成树)

    题目: Description The Head Elder of the tropical island of Lagrishan has a problem. A burst of foreign ...

  5. HDU 1301 Jungle Roads (最小生成树,基础题,模版解释)——同 poj 1251 Jungle Roads

    双向边,基础题,最小生成树   题目 同题目     #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include<stri ...

  6. [ An Ac a Day ^_^ ] [kuangbin带你飞]专题六 最小生成树 POJ 1251 Jungle Roads

    题意: 有n个点 每个点上有一些道路 求最小生成树 解释下输入格式 A n v1 w1 v2 w2 A点上有n条边 A到v1权值是w1 A到v2权值是w2 思路: 字符串处理之后跑kruskal求最小 ...

  7. POJ - 1251 Jungle Roads (最小生成树&并查集

    #include<iostream> #include<algorithm> using namespace std; ,tot=; const int N = 1e5; ]; ...

  8. POJ 1251 Jungle Roads(Kruskal算法求解MST)

    题目: The Head Elder of the tropical island of Lagrishan has a problem. A burst of foreign aid money w ...

  9. POJ 1251 Jungle Roads (zoj 1406) MST

    传送门: http://poj.org/problem?id=1251 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=406 P ...

随机推荐

  1. AC自动机-算法详解

    What's Aho-Corasick automaton? 一种多模式串匹配算法,该算法在1975年产生于贝尔实验室,是著名的多模式匹配算法之一. 简单的说,KMP用来在一篇文章中匹配一个模式串:但 ...

  2. .NET4.5新特性之异步编程(Async和Await)的使用

    一.简介 首先来看看.net的发展中的各个阶段的特性:NET 与C# 的每个版本发布都是有一个"主题".即:C#1.0托管代码→C#2.0泛型→C#3.0LINQ→C#4.0动态语 ...

  3. VS2010 VS2012 VS2013 VS2015启动调试时老是提示正在下载公共符号

    VS2010 VS2012 VS2013 VS2015启动调试时老是提示正在下载公共符号,下载一些.dll文件,点取消后也能继续调试,但特别慢.解决方法:工具-选项,或者调试-选项和设置,将调试下的& ...

  4. C++双缓冲多线程分析大文件词频

    实习生活告一段落,我正式从一名.NET程序员转入Java阵营,不得不说刚开始用Java的东西是多么的不习惯,但是经过三个月的使用与开发,我也发现了Java的优势:不在于语言,而在于开源.这意味着有更多 ...

  5. go-使用 unsafe 修改 struct 中的 field 的值

    以下是方法,不要纠结原理,等东西积累多了,你才有能力纠结原理: 首先,你需要有一个这样的函数,这是在 nsq 的源码里直接抄过来的: func unsafeValueOf(val reflect.Va ...

  6. POI读取EXCEL(2007以上)

    import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.InputStream; im ...

  7. 菜鸟快飞之JavaScript对象、原型、继承(一)

    有前辈说过,在JavaScript中,一切皆对象.由此可见,作为JavaScript的核心之一,对象是有多么重要.虽然今天走亲戚有点累,但还是得写写这个对象,免得吃几天好的,就又忘光了. 1.创建对象 ...

  8. Sublime Text通过插件编译Sass为CSS及中文编译异常解决

    虽然PostCSS才是未来,但是Sass成熟稳定,拥有一大波忠实的使用者,及开源项目,且最近Bootstrap 4 alpha也从Less转到Sass了.所以了解Sass还是非常有必要的. 基于快速开 ...

  9. 无法解决“Microsoft.SharePoint.Security, Version=15.0.0.0,”与“Microsoft.SharePoint.Security, Version=14.0.0.0”之间的冲突

    VisualStudio 2013创建控制台项目,.NetFramework选为4.5.生成目标平台:x64.然后添加对Microsoft.SharePoint.dll的引用. 生成项目时," ...

  10. 在 ASP.NET CORE 中使用 SESSION

    Session 是保存用户和 Web 应用的会话状态的一种方法,ASP.NET Core 提供了一个用于管理会话状态的中间件.在本文中我将会简单介绍一下 ASP.NET Core 中的 Session ...