POJ3026:Borg Maze (最小生成树)
Borg Maze
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 18644 | Accepted: 5990 | 
题目链接:http://poj.org/problem?id=3026
Description:
The Borg is an immensely powerful race of enhanced humanoids from the delta quadrant of the galaxy. The Borg collective is the term used to describe the group consciousness of the Borg civilization. Each Borg individual is linked to the collective by a sophisticated subspace network that insures each member is given constant supervision and guidance.
Your task is to help the Borg (yes, really) by developing a program which helps the Borg to estimate the minimal cost of scanning a maze for the assimilation of aliens hiding in the maze, by moving in north, west, east, and south steps. The tricky thing is that the beginning of the search is conducted by a large group of over 100 individuals. Whenever an alien is assimilated, or at the beginning of the search, the group may split in two or more groups (but their consciousness is still collective.). The cost of searching a maze is definied as the total distance covered by all the groups involved in the search together. That is, if the original group walks five steps, then splits into two groups each walking three steps, the total distance is 11=5+3+3.
Input:
On the first line of input there is one integer, N <= 50, giving the number of test cases in the input. Each test case starts with a line containg two integers x, y such that 1 <= x,y <= 50. After this, y lines follow, each which x characters. For each character, a space `` '' stands for an open space, a hash mark ``#'' stands for an obstructing wall, the capital letter ``A'' stand for an alien, and the capital letter ``S'' stands for the start of the search. The perimeter of the maze is always closed, i.e., there is no way to get out from the coordinate of the ``S''. At most 100 aliens are present in the maze, and everyone is reachable.
Output:
For every test case, output one line containing the minimal cost of a succesful search of the maze leaving no aliens alive.
Sample Input:
2
6 5
#####
#A#A##
# # A#
#S ##
#####
7 7
#####
#AAA###
# A#
# S ###
# #
#AAA###
#####
Sample Output:
8
11
题意:
从S点出发,目的是要到达所有外星人的位置。然后在起点或者有外星人的点,可以进行“分组”,也就是进行多条路径搜索。
最后的总代价定义为所有组行走的步数之和。比如这个组一开始走了5步,然后分为两组,各走三步,最终总代价为11步。
问的就是所有外星人位置被到达后的最小总代价为多少。
题解:
这个看似是搜索...也很像是搜索。如果不是在最小生成树专题里面,我估计也不会想到最小生成树。
其实这个题如果能够想到最小生成树就简单了,最终的目的转化为S以及所有的A都连通嘛,并且最小代价。
那么就直接先bfs求出两点间的最短距离,然后根据距离信息建图,跑最小生成树就行了。
代码如下:
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>
#include <queue>
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
const int N = ;
int t,n,m;
int num[N][N],d[N][N];
char mp[N][N];
int dx[]={,-,,},dy[]={,,,-};
struct Edge{
int u,v,w;
bool operator < (const Edge &A)const{
return w<A.w;
}
}e[N*N<<];
struct node{
int x,y;
};
int f[N*N];
int tot,cnt;
int find(int x){
return f[x]==x?f[x]:f[x]=find(f[x]);
}
int Kruskal(){
int ans=;
for(int i=;i<=;i++) f[i]=i;
for(int i=;i<=tot;i++){
int fx=find(e[i].u),fy=find(e[i].v);
if(fx==fy) continue ;
f[fx]=fy;
ans+=e[i].w;
}
return ans ;
}
bool ok(int x,int y){
return x>= && x<=n && y>= && y<=m && mp[x][y]!='#';
}
void bfs(int sx,int sy){
queue <node> q;
memset(d,INF,sizeof(d));d[sx][sy]=;
node now;
now.x=sx;now.y=sy;
q.push(now);
while(!q.empty()){
node cur = q.front();q.pop();
for(int i=;i<;i++){
int x=cur.x+dx[i],y=cur.y+dy[i];
if(!ok(x,y)||d[x][y]<=d[cur.x][cur.y]+) continue ;
d[x][y]=d[cur.x][cur.y]+;
now.x=x;now.y=y;
q.push(now);
if(mp[x][y]=='A'||mp[x][y]=='S'){
e[++tot].u=num[sx][sy];e[tot].v=num[x][y];e[tot].w=d[x][y];
}
}
}
}
int main(){
cin>>t;
while(t--){
scanf("%d%d",&m,&n);
tot = cnt = ;
char c;
while(){
scanf("%c",&c);
if(c!=' ') break ;
}
int first=;
memset(num,,sizeof(num));
for(int i=;i<=n;i++){
getchar();
first=;
for(int j=;j<=m;j++){
scanf("%c",&mp[i][j]);
if(mp[i][j]=='S'||mp[i][j]=='A') num[i][j]=++cnt;
}
}
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
if(num[i][j]) bfs(i,j);
}
}
sort(e+,e+tot+);
int ans = Kruskal();
cout<<ans<<endl;
}
return ;
}
POJ3026:Borg Maze (最小生成树)的更多相关文章
- POJ3026 Borg Maze(最小生成树)
		
题目链接. 题目大意: 任意两点(点表示字母)可以连线,求使所有点连通,且权值和最小. 分析: 第一感觉使3维的BFS.但写着写着,发现不对. 应当用最小生成树解法.把每个字母(即A,或S)看成一个结 ...
 - POJ3026——Borg Maze(BFS+最小生成树)
		
Borg Maze DescriptionThe Borg is an immensely powerful race of enhanced humanoids from the delta qua ...
 - poj 3026 Borg Maze 最小生成树 + 广搜
		
点击打开链接 Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7097 Accepted: 2389 ...
 - POJ3026 Borg Maze                                                                                            2017-04-21 16:02             50人阅读              评论(0)              收藏
		
Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14165 Accepted: 4619 Descri ...
 - 快速切题 poj 3026 Borg Maze 最小生成树+bfs prim算法 难度:0
		
Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8905 Accepted: 2969 Descrip ...
 - POJ3026 Borg Maze(Prim)(BFS)
		
Borg Maze Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 12729 Accepted: 4153 Descri ...
 - POJ3026 Borg Maze(bfs求边+最小生成树)
		
Description The Borg is an immensely powerful race of enhanced humanoids from the delta quadrant of ...
 - (POJ 3026) Borg Maze    最小生成树+bfs
		
题目链接:http://poj.org/problem?id=3026. Description The Borg is an immensely powerful race of enhanced ...
 - poj 3026 Borg Maze (最小生成树+bfs)
		
有几个错误,调试了几个小时,样例过后 1Y. 题目:http://poj.org/problem?id=3026 题意:就是让求A们和S的最小生成树 先用bfs找每两点的距离,再建树.没剪枝 63MS ...
 
随机推荐
- Ubuntu14.04 panic --not syncing: Attempt to kill init 解决方法
			
Ubuntu14.04 panic --not syncing: Attempt to kill init 解决方法 工作电脑装了一个虚拟机玩玩,胡乱下载了一些软件,apt-get了不少操作,后来重启 ...
 - 【cover-view、cover-image】 覆盖组件说明
			
cover-view.cover-image 这两类覆盖组件用于显示在一些特殊组件上方(map.video.canvas.camera.live-player.live-pusher). 这类组件一般 ...
 - 90 [LeetCode] Subsets2
			
Given a collection of integers that might contain duplicates, nums, return all possible subsets (the ...
 - Faster RCNN论文解析
			
Faster R-CNN由一个推荐区域的全卷积网络和Fast R-CNN组成, Fast R-CNN使用推荐区域.整个网络的结构如下: 1.1 区域推荐网络 输入是一张图片(任意大小), 输出是目标推 ...
 - LeetCode 102 ——二叉树的层次遍历
			
1. 题目 2. 解答 定义一个存放树中数据的向量 data,一个存放树的每一层数据的向量 level_data 和一个存放每一层节点的队列 node_queue. 如果根节点非空,根节点进队,然后循 ...
 - C#调用mingw的so库时无法加载DLL###.so 找不到指定的模块
			
使用C#调用mingw的so,报了c# 无法加载DLL“###.so”,: 找不到指定的程序. (异常来自 HRESULT:0x8007007E)开始以为是dll路径问题,使用全路径确认正确后仍然无法 ...
 - centos环境配置(nginx,node.js,mysql)
			
1.安装 Install GCC and Development Tools on a CentOS yum group install "Development Tools" n ...
 - NFC进场通信总结概述
			
简介 本文介绍Nokia设备所支持的近场通信技术(NFC)及相关的功能.旨在为使用 Qt/Symbian/Java™ API为Nokia手机开发应用的开发者 刚开始接触NFC开发时提供有用的信息. 什 ...
 - Thunder团队——事后诸葛亮会议
			
小组名称:Thunder 项目名称:爱阅APP 小组成员:王航 李传康 代秋彤 邹双黛 苗威 宋雨 胡佑蓉 杨梓瑞 一.设想和目标 1.我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型 ...
 - Alpha 冲刺报告(3/10)
			
Alpha 冲刺报告 队名:洛基小队 峻雄(组长) 已完成:开始编写角色的移动脚本 明日计划:继续学习并进行脚本编写 剩余任务:物品背包交互代码 困难:如何把各个模块的脚本整合起来 --------- ...