标签:des style blog http io ar color os sp

2 3 ##@ #.# 1 2 2 4 4 #@## .... #### .... 2 2 1 2 4 0 0
-1 5
#include <iostream>
#include <cstring>
#include <queue>
#include <cstdio>
#include <algorithm>
using namespace std;
int n , m,k;
int visit[110][110];
int p[5];
char g[110][110];
int sx,sy;
int dx[] = {-1,1,0,0};
int dy[] = {0,0,-1,1};
struct node
{
int x,y,step;
node(int a,int b, int c): x(a),y(b),step(c) {}
node(){}
}ss[6];
int bfs()
{
queue<node> q;
q.push(node(sx,sy,0));
memset(visit,0,sizeof(visit));
visit[sx][sy] = 1;
for(int i = 0; !q.empty(); )
{
node temp = q.front();
q.pop();
for(int j = 0; j < 4; j++)
{
int xx = temp.x + dx[j];
int yy = temp.y + dy[j];
int step = temp.step + 1;
if(xx < 0 || yy < 0 || xx >= n || yy >= m || g[xx][yy] == '#' || visit[xx][yy]) continue;
int flag = xx == ss[p[i]].x && yy == ss[p[i]].y;
if(flag)
{
while(!q.empty()) q.pop();
memset(visit,0,sizeof(visit));
if(++i == k) return step;
}
q.push(node(xx,yy,step));
visit[xx][yy] = 1;
if(flag) break;
}
}
return -1;
}
int main()
{
#ifdef xxz
freopen("in.txt","r",stdin);
#endif
while(scanf("%d%d",&n,&m)!=EOF && n != 0)
{
for(int i = 0; i < n; i++)
{
scanf("%s",g[i]);
for(int j = 0; j < m; j++)
{
if(g[i][j] == '@')
{
sx = i;
sy = j;
}
}
}
scanf("%d",&k);
int Case = 1;
for(int i = 0; i < k; i++)
{
scanf("%d%d",&ss[i].x,&ss[i].y);
ss[i].x--;
ss[i].y--;
p[i] = i;
Case *= i+1;
}
int ans = -1;
while(Case--)
{
int temp = bfs();
// cout<<temp<<endl;
if(temp > -1 && (temp < ans || ans == -1)) ans = temp;
next_permutation(p,p+k);
}
printf("%d\n",ans);
}
return 0;
}标签:des style blog http io ar color os sp
原文地址:http://blog.csdn.net/u013445530/article/details/41291359