zoukankan      html  css  js  c++  java
  • hdoj 2717 Catch That Cow【bfs】

    Catch That Cow

    Time Limit: 5000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 9276    Accepted Submission(s): 2907


    Problem Description
    Farmer John has been informed of the location of a fugitive cow and wants to catch her immediately. He starts at a point N (0 ≤ N ≤ 100,000) on a number line and the cow is at a point K (0 ≤ K ≤ 100,000) on the same number line. Farmer John has two modes of transportation: walking and teleporting.

    * Walking: FJ can move from any point X to the points X - 1 or X + 1 in a single minute
    * Teleporting: FJ can move from any point X to the point 2 × X in a single minute.

    If the cow, unaware of its pursuit, does not move at all, how long does it take for Farmer John to retrieve it?
     
    Input
    Line 1: Two space-separated integers: N and K
     
    Output
    Line 1: The least amount of time, in minutes, it takes for Farmer John to catch the fugitive cow.
     
    Sample Input
    5 17
     
    Sample Output
    4
     
    题意:人在n位置处,牛在k位置处,牛不动问人最短多少分钟可以捉到牛,人有两种移动方法
            1、一分钟移动一步n-1或者n+1
            2、一分钟移动2*n步;
    #include<stdio.h>
    #include<string.h>
    #include<queue>
    #define MAX 1000100
    using namespace std;
    int n,m;
    int vis[MAX];
    struct node
    {
    	int x;
    	int step;
    	friend bool operator < (node a,node b)
    	{
    		return a.step>b.step;
    	}
    };
    int judge(int x)
    {
    	if(x < 0||x > MAX||vis[x])
    	    return 0;
    	return 1;
    }
    void bfs(int n,int k)
    {
    	int i,j;
    	priority_queue<node>q;
    	node beg,end;
    	beg.x=n;
    	beg.step=0;
    	q.push(beg);
    	vis[n]=1;
    	while(!q.empty())
    	{
    		beg=q.top();
    		q.pop();
    		if(beg.x==k)
    		{
    			printf("%d
    ",beg.step);
    			return ;
    		}
    		end.x=beg.x-1;
    		if(judge(end.x))
    		{
    			vis[end.x]=1;
    			end.step=beg.step+1;
    			q.push(end);
    		}
    		end.x=beg.x+1;
    		if(judge(end.x))
    		{
    			vis[end.x]=1;
    			end.step=beg.step+1;
    			q.push(end);
    		}
    		end.x=beg.x*2;
    		if(judge(end.x))
    		{
    			vis[end.x]=1;
    			end.step=beg.step+1;
    			q.push(end);
    		}
    	}
    }
    int main()
    
    {
    	int i;
    	while(scanf("%d%d",&n,&m)!=EOF)
    	{
    		memset(vis,0,sizeof(vis));
    		bfs(n,m);
    	}
    	return 0;
    }
    

      

  • 相关阅读:
    Centos配置Apache phpadmin环境
    Linux添加FTP用户并设置权限
    Java中的过滤器
    【eclipse】注释模版
    [ci db操作]
    给vmware的Linux虚拟机添加硬盘
    基于LVDS/M-LVDS的数据通信
    如何找回丢失的硬盘分区表?
    vc++怎么可以直接刷掉MBR?搞笑的吧
    EFI、UEFI、MBR、GPT的区别
  • 原文地址:https://www.cnblogs.com/tonghao/p/4707022.html
Copyright © 2011-2022 走看看