题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=20846

POJ 3026是同样的题,但是内存要求比较严格,并是没有过。。。

对以迷宫形式给定的一些点求最小生成树,不过这里的边并不是抽象的两点间笛卡尔距离,也不是折线距离(迷宫中有障碍),而是需要用四个方向的搜索来求。

用bfs求出任两点间的最短距离后,可用kruscal求出最小生成树。

这次值得一提的是对并查集的一点改造:由于每个顶点由一组(x,y)坐标唯一确定,而并查集的元素应是能用一个整数唯一确定的,所以要将(x,y)坐标的集合映射到整数集合。联想到了最近课内学的信道的“分频复用”,和实时操作系统uCOS-II的任务就绪表的数据结构和算法。于是就有了如下做法,其实很常见了~

x,y坐标范围是[0,50],50<2^6,因此可用一个int型(2^31)的低7位存y坐标,8~14位存x坐标,14<31,一个整型完全可以存下。这样一个点可由一个int型数(低14位)完全确定,并且以每维2^14为size开二维数组vis和dis也可以开下。

经检验这个做法可行,其实就是模仿底层,把基本型当作结构体看待,每位的语义是约定好的,自己编码自己解码~

代码在UVA过了(没限制内存),在POJ上还是MLE,待我好好补一补搜索再来更新吧~

 #include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <stack>
#include <vector>
#include <queue>
using namespace std;
const int MAX_S=;
const int MAX_N=;
struct Point
{
int x,y;
Point(){}
Point(int xx,int yy):x(xx),y(yy){}
}; struct Edge
{
Point u,v;
int w;
}e[MAX_N*MAX_N];
bool cmp(const Edge e1,const Edge e2)
{
return e1.w<e2.w;
} int par[(MAX_S<<)+MAX_S];
void init()
{
memset(par,-,sizeof(par));
}
int find(int x)
{
if(par[x]==-) return x;
return par[x]=find(par[x]);
}
void unite(Point p1,Point p2)
{
int x=(p1.x<<)+p1.y;
int y=(p2.x<<)+p2.y;
x=find(x);
y=find(y);
if(x==y) return ;
par[x]=y;
} bool same(Point p1,Point p2)
{
int x=(p1.x<<)+p1.y;
int y=(p2.x<<)+p2.y;
return find(x)==find(y);
} int T;
int w,h;
int n,m;
char maze[MAX_S][MAX_S];
int dx[]={,,,-},dy[]={,-,,}; typedef pair<Point,int> P;
int vis[MAX_S][MAX_S];
int dis[(MAX_S<<)+MAX_S][(MAX_S<<)+MAX_S]; void bfs(int x,int y)
{
int poi=(x<<)+y;
memset(vis,,sizeof(vis));
queue<P> que;//Point,step
que.push(P(Point(x,y),));
vis[x][y]=;
while(!que.empty())
{
Point p=que.front().first;
int step=que.front().second;
que.pop();
for(int i=;i<;i++)
{
int nx=p.x+dx[i];
int ny=p.y+dy[i];
int npoi=(nx<<)+ny;
if(nx<||ny<||w<=nx||w<=ny||vis[nx][ny]) continue;
if(maze[nx][ny]=='#'){vis[nx][ny]=; continue;}
if(dis[poi][npoi]||poi==npoi) continue;
que.push(P(Point(nx,ny),step+));
vis[nx][ny]=;
if((maze[nx][ny]=='A'||maze[nx][ny]=='S')&&poi!=npoi)
{
e[m].u=Point(x,y);
e[m].v=Point(nx,ny);
dis[npoi][poi]=dis[poi][npoi]=e[m].w=step+;
m++;
}
}
}
} int kruscal()
{
init();
int ans=;
for(int i=;i<m;i++)
{
if(!same(e[i].u,e[i].v))
{
unite(e[i].u,e[i].v);
ans+=e[i].w;
}
}
return ans;
} int main()
{
freopen("3026.txt","r",stdin);
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&w,&h);
n=;
getchar();
for(int i=;i<h;i++)
{
fgets(maze[i],w,stdin);
gets(maze[i+]);
}
m=;
memset(dis,,sizeof(dis));
for(int i=;i<h;i++)
{
for(int j=;j<w;j++)
if(maze[i][j]=='A'||maze[i][j]=='S') bfs(i,j);
}
/*
for(int i=0;i<m;i++)
printf("%d %d -> %d %d = %d\n",e[i].u.x,e[i].u.y,e[i].v.x,e[i].v.y,e[i].w);
*/
sort(e,e+m,cmp);
printf("%d\n",kruscal());
}
return ;
}

【UVA 10307 Killing Aliens in Borg Maze】最小生成树, kruscal, bfs的更多相关文章

  1. poj 3026 Borg Maze 最小生成树 + 广搜

    点击打开链接 Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7097   Accepted: 2389 ...

  2. 快速切题 poj 3026 Borg Maze 最小生成树+bfs prim算法 难度:0

    Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8905   Accepted: 2969 Descrip ...

  3. POJ3026:Borg Maze (最小生成树)

    Borg Maze Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 18644   Accepted: 5990 题目链接:h ...

  4. (POJ 3026) Borg Maze 最小生成树+bfs

    题目链接:http://poj.org/problem?id=3026. Description The Borg is an immensely powerful race of enhanced ...

  5. poj 3026 Borg Maze (最小生成树+bfs)

    有几个错误,调试了几个小时,样例过后 1Y. 题目:http://poj.org/problem?id=3026 题意:就是让求A们和S的最小生成树 先用bfs找每两点的距离,再建树.没剪枝 63MS ...

  6. POJ3026 Borg Maze(最小生成树)

    题目链接. 题目大意: 任意两点(点表示字母)可以连线,求使所有点连通,且权值和最小. 分析: 第一感觉使3维的BFS.但写着写着,发现不对. 应当用最小生成树解法.把每个字母(即A,或S)看成一个结 ...

  7. POJ 3026 Borg Maze 广搜(BFS)+最小生成树

    题意:从S出发,去抓每一个A,求总路径最短长度.在S点和A点人可以分身成2人,不过一次只能让一个人走. 思路是先利用BFS求出各点之间的距离,建成图,再套用最小生成树模板. 一次性A了.不过觉得在判断 ...

  8. Borg Maze POJ - 3026 (BFS + 最小生成树)

    题意: 求把S和所有的A连贯起来所用的线的最短长度... 这道题..不看discuss我能wa一辈子... 输入有坑... 然后,,,也没什么了...还有注意 一次bfs是可以求当前点到所有点最短距离 ...

  9. Borg Maze - poj 3026(BFS + Kruskal 算法)

    Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9821   Accepted: 3283 Description The B ...

随机推荐

  1. HttpApplication处理对象与HttpModule处理模块 (第三篇)

    一.HttpApplication对象简述 在HttpRuntime创建了HttpContext对象之后,HttpRuntime将随后创建一个用于处理请求的对象,这个对象的类型为HttpApplica ...

  2. iphone6闪存检测

    iPhone6自从发布以后一直又不少的诟病和非议,比如一机难求,容易掰弯,程序崩溃等, 甚至传出了苹果将要召回这些问题设备,最近有人终于查出了iPhone6安装大量程序后崩溃的原因,原因就是大容量的i ...

  3. 【转】android 物理按键

    关键词:android   按键  矩阵按键 AD按键  平台信息: 内核:linux2.6/linux3.0 系统:android/android4.0 平台:S5PV310(samsung exy ...

  4. java各公司笔试题集1

    IBM笔试题 注:IBM笔试题一小时之内完成,题目全部用英文描述,这里用中文表述 一.名词解释 1.Eclipse 2.J2EE 3.EJB 4.Ajax 5.Web service 二.找出以下代码 ...

  5. Bridging signals(二分 二分+stl dp)

    欢迎参加——每周六晚的BestCoder(有米!) Bridging signals Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 6 ...

  6. mysql的常用操作的封装

    1.概述: 为了把繁琐的操作简化成简单的类,设计了2个类用来封装了mysql的常用操作,以便使用者可以方便地使用. 2.组成 1)数据库操作类CDatabaseConnect 2)SQL对象类CSql ...

  7. 并查集+二分-hdu-4750-Count The Pairs

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4750 题目大意: 给一无向图,n个点,m条边,每条边有个长度,且不一样.定义f(i,j)表示从节点i ...

  8. Web Service中的XFire 传输List 自定义对象.

    我把这个创建的步骤和代码的贴出来,. 首先新建一个工程,取名就随便点啦..MyWebService,然后复制jar包到lib目录下, 创建包,建立接口..写一个javaBean的类, 以下是一个简单的 ...

  9. Cocos2d-x游戏开发CCBAnimationManager控制动画

    CocosBuilder能方便的编辑各种动画.大部分动画都是以独立片段的形式存在的. 须要由程序来控制何时播放. 管理ccbi文件的动画播放有个专门的类:CCBAnimationManager 大致的 ...

  10. 简述uwsgi使用一个服务启动多个文件的用法

    [场景篇] 为了节省端口的占用,将N个flask应用服务——每个对应一个文件(web.py.django也一样)合并为一个端口服务来启用 [寻思篇] 通常的做法:每个文件配置一个xml 或者 ini文 ...