poj 1251 Jungle Roads (最小生成树)
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
题意:
给定多个点,和点与点之间的距离, 求最小让其连接起来的线路的总和。
经典的最小生成树问题。 使用 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 (最小生成树)的更多相关文章
- POJ 1251 Jungle Roads - C语言 - Kruskal算法
Description The Head Elder of the tropical island of Lagrishan has a problem. A burst of foreign aid ...
- POJ 1251 Jungle Roads(最小生成树)
题意 有n个村子 输入n 然后n-1行先输入村子的序号和与该村子相连的村子数t 后面依次输入t组s和tt s为村子序号 tt为与当前村子的距离 求链接全部村子的最短路径 还是裸的最小生成树咯 ...
- POJ 1251 Jungle Roads (prim)
D - Jungle Roads Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u Su ...
- POJ 1251 Jungle Roads (最小生成树)
题目: Description The Head Elder of the tropical island of Lagrishan has a problem. A burst of foreign ...
- HDU 1301 Jungle Roads (最小生成树,基础题,模版解释)——同 poj 1251 Jungle Roads
双向边,基础题,最小生成树 题目 同题目 #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include<stri ...
- [ 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求最小 ...
- POJ - 1251 Jungle Roads (最小生成树&并查集
#include<iostream> #include<algorithm> using namespace std; ,tot=; const int N = 1e5; ]; ...
- 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 ...
- POJ 1251 Jungle Roads (zoj 1406) MST
传送门: http://poj.org/problem?id=1251 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=406 P ...
随机推荐
- 理解浏览器历史记录(2)-hashchange、pushState
本文也是一篇基础文章.继上文之后,本打算去研究pushState,偶然在一些信息中发现了锚点变化对浏览器的历史记录也会影响,同时锚点的变化跟pushState也有一些关联.所以就花了点时间,把这两个东 ...
- 关于 ASP.NET MVC 中的视图生成
在 ASP.NET MVC 中,我们将前端的呈现划分为三个独立的部分来实现,Controller 用来控制用户的操作,View 用来控制呈现的内容,Model 用来表示处理的数据. 从控制器到视图 通 ...
- c#面向对象基础技能——学习笔记(三)基于OOP思想研究对象的【方法】
实例方法:(解决问题的步骤)完成某功能的各种语句的组合 编写方法要考虑的内容: 1.通过项目需求,确定各方法的任务.功能: 2.方法的可访问性(默认是private):(字段private 属性int ...
- 三个linux系统共存,修改默认启动
一个mint,一个ubuntu,想要默认启动ubuntu,那么咱们这么来:修改启动顺序,我们需要修改Ubuntu的GRUB配置文件.使用常见的编辑程序如"gedit"就可以很方便 ...
- C++ STL简述
前言 最近要找工作,免不得要有一番笔试,今年好像突然就都流行在线笔试了,真是搞的我一塌糊涂.有的公司呢,不支持Python,Java我也不会,C有些数据结构又有些复杂,所以是时候把STL再看一遍了-不 ...
- mysql 安装
编译环境yum install gcc gcc-c++ ncurses-devel perl 依赖yum install boost boost-devel boost-doc 安装cmake wge ...
- node.js express安装及示例网站搭建
1.首先肯定是要安装Node.JS windows cmd依次输入如下命令: cd C:\Program Files\nodejs\ npm install -g expressnpm install ...
- 最新Android系统版本与API等级对应关系表
最新Android系统版本与API等级对应关系表 从Android官网拷过来的,方便查阅... 官网地址:https://developer.android.com/guide/topics/mani ...
- Learning the standard of C++11
It's a very useful website of en.cppreference.com. It lists a huge number of information about the l ...
- SQL Server 2012 新特性:新增和修改函数
转换函数 1.PARSE Parse是把字符串类型转化为想要的类型,看看和convert和cast的区别 SELECT PARSE ('2.111111' AS f ...