【ZOJ2276】Lara Croft(bfs)
BUPT2017 wintertraining(16) #4 D
ZOJ - 2276
题意
n个数字绕成环,有两个指示数字的方块,每次可以顺时针或逆时针移动其中一个,步数是它当前位置的数字a[i],给定它们的初始位置,求最少几步可使两个方块停在一个位置上的,或永远不可能。
题解
bfs,两个方块当前位置为状态。
代码
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>
#define N 105
using namespace std;
struct node{
int p,q,k;
};
int n,a[N],p,q,vis[N][N];
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
int bfs(){
queue<node>que;
memset(vis,0,sizeof vis);
que.push((node){p,q,0});
while(!que.empty()){
node k=que.front();
que.pop();
for(int i=0;i<4;i++){
int np=(k.p+a[k.p]*dx[i]+n)%n,nq=(k.q+a[k.q]*dy[i]+n)%n;
if(np==nq)return k.k+1;
if(!vis[np][nq]){
que.push((node){np,nq,k.k+1});
vis[np][nq]=1;
}
}
}
return -1;
}
int main() {
while(scanf("%d",&n),n){
for(int i=0;i<n;i++)
scanf("%d",&a[i]);
scanf("%d%d",&p,&q);
int ans=bfs();
if(ans==-1)puts("Lara is traped!");
else printf("open it on the %dth move!\n",ans);
}
return 0;
}
┆凉┆暖┆降┆等┆幸┆我┆我┆里┆将┆ ┆可┆有┆谦┆戮┆那┆ ┆大┆始┆ ┆然┆
┆薄┆一┆临┆你┆的┆还┆没┆ ┆来┆ ┆是┆来┆逊┆没┆些┆ ┆雁┆终┆ ┆而┆
┆ ┆暖┆ ┆如┆地┆站┆有┆ ┆也┆ ┆我┆ ┆的┆有┆精┆ ┆也┆没┆ ┆你┆
┆ ┆这┆ ┆试┆方┆在┆逃┆ ┆会┆ ┆在┆ ┆清┆来┆准┆ ┆没┆有┆ ┆没┆
┆ ┆生┆ ┆探┆ ┆最┆避┆ ┆在┆ ┆这┆ ┆晨┆ ┆的┆ ┆有┆来┆ ┆有┆
┆ ┆之┆ ┆般┆ ┆不┆ ┆ ┆这┆ ┆里┆ ┆没┆ ┆杀┆ ┆来┆ ┆ ┆来┆