POJ 3278 Catch That Cow --- 简单BFS
/* POJ 3278 Catch That Cow --- 简单BFS */ #include <cstdio> #include <queue> #include <cstring> using namespace std; const int maxn = 100005; bool visit[maxn]; int step[maxn]; int bfs(int n, int k){ if (n == k) return 0; memset(visit, 0, sizeof visit); queue<int> q; //对中存储已访问但下一个点待判断的结点 q.push(n); step[n] = 0; visit[n] = 1; int x,next; while (!q.empty()){ x = q.front(); q.pop(); for (int i = 0; i < 3; ++i){ //i = 0,1,2表示分别按不同的方向广搜 if (i == 0) next = x - 1; else if (i == 1) next = x + 1; else next = x * 2; //是否越界和是否已访问的判断 if (visit[next] || next < 0 ||next >= maxn) continue; visit[next] = 1; step[next] = step[x] + 1; //步数+1 if (next == k) return step[next]; q.push(next); } //q.pop(); } return -1; } int main() { int n, k; while (scanf("%d%d", &n, &k) == 2){ printf("%d\n", bfs(n, k)); } return 0; }