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. GO语言之channel

    前言: 初识go语言不到半年,我是一次偶然的机会认识了golang这门语言,看到他简洁的语法风格和强大的语言特性,瞬间有了学习他的兴趣.我是很看好go这样的语言的,一方面因为他有谷歌主推,另一方面他确 ...

  2. User Growth Using Deeplink. (part1)

    转载请注明来源 http://www.cnblogs.com/hucn/p/5917924.html 活跃人数是衡量app一项关键指标, dau, mau, 有了流量才能给业务发展提供养分和空间. a ...

  3. AngularJS中get请求URL出现跨域问题

    今天早上帮助同学看了一个AngularJS的问题,主要是请求中出现了跨域访问,请求被阻止. 下面是她给我的代码: <html lang="en" ng-app="m ...

  4. 常用JavaScript触发事件

    事件句柄 onclick=JavaScript:鼠标单击某个对象.3 ondblclick=JavaScript:鼠标双击某个对象.3 onmousedown=JavaScript:某个鼠标键被按下. ...

  5. 02 button的练习

    private void button1_Click(object sender, EventArgs e) { MessageBox.Show("我也喜欢你!"); //if ( ...

  6. 关于xml加载提示: Error on line 1 of document : 前言中不允许有内容

    我是在java中做的相关测试, 首先粘贴下报错: 读取xml配置文件:xmls\property.xml org.dom4j.DocumentException: Error on line 1 of ...

  7. Java Web之网上购物系统(注册、登录、浏览商品、添加购物车)

    眼看就要期末了,我的专业课也迎来了第二次的期末作业---------<网上购物系统>.虽然老师的意图是在锻炼我们后台的能力,但是想着还是不利用网上的模板,准备自己写,以来别人写的静态页看不 ...

  8. bitnami redmine版本由2.3.1升级至3.2.2过程

    环境: 操作系统为ubuntu13.**版本,非长期支持版. 安装目录:/opt/redmine-2.3.1-0/ 所有者用户:root 安装过程: 1. 备份2.3.1数据库 sudo /opt/r ...

  9. AngularJS 过滤器

    过滤器可以使用一个管道字符(|)添加到表达式和指令中 AngularJS 过滤器可用于转换数据: currency 格式化数字为货币格式. filter 从数组项中选择一个子集. lowercase ...

  10. mac 抓包工具charles v3.9.3 安装破解步骤

    一.下载 先到它的官网http://www.charlesproxy.com/可下载到最新版本,这个下载有点慢,我已经将它放到网盘中了:http://pan.baidu.com/s/1skTXRIl ...