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. Windows 10 安装 Sql Server 2014 反复提示需要安装 .NET Framework 3.5 SP1 的解决方案

    一.首先安装.NET Framework 3.5: 离线安装方式: 1.装载相对应的系统安装盘,我是Windows 10 x64 企业版,所以装载Windows 10 x64 企业版安装镜像ISO,盘 ...

  2. jvm内存区域

    概述 jvm内存分为几个区域: 程序计数器 虚拟机栈 本地方法栈 堆 方法区 运行时常量池 直接内存 这些内存区域是在java进程中细分的,为java程序提供服务 不同的区域存储的内容不一样,生命周期 ...

  3. Android 防止控件被重复点击

    转载: 工具类: public class Utils { private static long lastClickTime; public static boolean isFastDoubleC ...

  4. app字体被放大效果发虚

    IOS App所有字体被放大,显示效果发虚 小小程序猿 我的博客:http://daycoding.com 分析原因: 由于新版本上线更换了LaunchImage,没有注意美工给的图片尺寸,由于图片尺 ...

  5. react-native DatePicker日期选择组件的实现

    本教程的实现效果如下: 为了实现其淡入/淡出的覆盖效果, 还有取消按钮, 在此用了一个三方的组件, 大家可以先安装一下: 三方组件的地址:https://github.com/eyaleizenber ...

  6. django 1.10 CSRF验证失败的解决过程

    最近工作闲,没事自学django,感觉这个最烦的就是各版本提供的api函数经常有变化,不是取消了就是参数没有了,网上搜到的帖子也没说明用的是什么版本的django,所以经常出现搬运过来的代码解决不了问 ...

  7. Atitit.android播放smb 网络邻居视频文件解决方案

    Atitit.android播放smb 网络邻居视频文件解决方案 Android4.4 1.1. Android4视频播放器不能直接地支持smb协议..子好先转换成个http流 1.2. ES文件浏览 ...

  8. iOS学习15之OC集合

    1.数组类 1> 回顾C语言数组 数组是一个有序的集合, 来存储相同数据类型的元素. 通过下标访问数组中的元素,下标从 0 开始. 2> 数组 数组是一个有序的集合,OC中的数组只能存储对 ...

  9. javascript-组合模式

    组合模式笔记 组合模式又称部分-整体模式,将对象组合成树形结构以表示'部分整体'的层次结构 组合模式使得用户对单个对象和组合对象的使用具有一致性 demo实例 :表单模块 要调用到前面学习到的寄生组合 ...

  10. 使用beautifulsoup与requests爬取数据

    1.安装需要的库 bs4 beautifulSoup  requests lxml如果使用mongodb存取数据,安装一下pymongo插件 2.常见问题 1> lxml安装问题 如果遇到lxm ...