5 17
4#include<cstdio> #include<cstring> #include<cmath> #include<cstdlib> #include<iostream> #include<algorithm> #include<queue> #include<stack> using namespace std; const int MAX=1000000; int f[3][2]={{1,-1},{1,1},{2,0}}; //关键 int visit[MAX]; int n,m; struct node { int x,num; }; void BFS(int x) { queue<node>q; node p,t; t.x=x; visit[t.x]=1; t.num=0; q.push(t); while(!q.empty()) { t=q.front(); q.pop(); if(t.x==n) { printf("%d\n",t.num); return; } for(int i=0;i<3;i++) { p.x=t.x*f[i][0]+f[i][1]; if(p.x>=0&&p.x<=MAX&&!visit[p.x]) { p.num=t.num+1; q.push(p); visit[p.x]=1; } } } } int main() { while(~scanf("%d%d",&m,&n)) //直接scanf("%d%d",&m,&n)就WA,这么任性我也是醉了 { memset(visit,0,sizeof(visit)); if(m==n) cout<<"0"<<endl; //必须判断一下 else BFS(m); } return 0; }
原文:http://blog.csdn.net/holyang_1013197377/article/details/44587289