首页 > 代码库 > poj3278
poj3278
#include<iostream> #define MAX 100001 int john,cow; int queue[MAX]; int vis[MAX]; int ans; void bfs() { int tail,head; tail=head=0; int start=john; queue[tail++]=start; vis[start]=1; while(head!=tail) { int cur,next; cur=queue[head++]; if(cur==cow) { ans=vis[cur]-1; return; } next=cur; next=cur+1; if(next>=0&&next<MAX&&vis[next]==0) { vis[next]=vis[cur]+1; queue[tail++]=next; } next=cur-1; if(next>=0&&next<MAX&&vis[next]==0) { vis[next]=vis[cur]+1; queue[tail++]=next; } next=2*cur; if(next>=0&&next<MAX&&vis[next]==0) { vis[next]=vis[cur]+1; queue[tail++]=next; } } } int main() { //freopen("input.txt","r",stdin); std::cin>>john>>cow; for(int i=0;i<MAX;i++) vis[i]=0; bfs(); std::cout<<ans; return 0; }
poj3278
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。