• hdoj-- Walking Ant


                                    Walking Ant

    Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other)
    Total Submission(s) : 13   Accepted Submission(s) : 9
    Problem Description
    Ants are quite diligent. They sometimes build their nests beneath flagstones. Here, an ant is walking in a rectangular area tiled with square flagstones, seeking the only hole leading to her nest.

    The ant takes exactly one second to move from one flagstone to another. That is, if the ant is on the flagstone with coordinates (x,y) at time t, she will be on one of the five flagstones with the following coordinates at time t+1:

    (x, y), (x+1, y), (x-1, y), (x, y+1), (x, y-1).

    The ant cannot go out of the rectangular area. The ant can visit the same flagstone more than once.

    Insects are easy to starve. The ant has to go back to her nest without starving. Physical strength of the ant is expressed by the unit "HP". Initially, the ant has the strength of 6 HP. Every second, she loses 1 HP. When the ant arrives at a flagstone with some food on it, she eats a small piece of the food there, and recovers her strength to the maximum value, i.e., 6 HP, without taking any time. The food is plenty enough, and she can eat it as many times as she wants.

    When the ant's strength gets down to 0 HP, she dies and will not move anymore. If the ant's strength gets down to 0 HP at the moment she moves to a flagstone, she does not effectively reach the flagstone: even if some food is on it, she cannot eat it; even if the hole is on that stone, she has to die at the entrance of her home.

    If there is a puddle on a flagstone, the ant cannot move there.

    Your job is to write a program which computes the minimum possible time for the ant to reach the hole with positive strength from her start position, if ever possible.


    Input

    The input consists of multiple maps, each representing the size and the arrangement of the rectangular area. A map is given in the following format.

    w h
    d11 d12 d13 ... d1w
    d21 d22 d23 ... d2w
    ...
    dh1 dh2 dh3 ... dhw

    The integers w and h are the numbers of flagstones in the x- and y-directions, respectively. w and h are less than or equal to 8. The integer dyx represents the state of the flagstone with coordinates (x, y) as follows.

    0: There is a puddle on the flagstone, and the ant cannot move there.
    1, 2: Nothing exists on the flagstone, and the ant can move there. `2' indicates where the ant initially stands.
    3: The hole to the nest is on the flagstone.
    4: Some food is on the flagstone.

    There is one and only one flagstone with a hole. Not more than five flagstones have food on them.

    The end of the input is indicated by a line with two zeros.

    Integer numbers in an input line are separated by at least one space character.


    Output

    For each map in the input, your program should output one line containing one integer representing the minimum time. If the ant cannot return to her nest, your program should output -1 instead of the minimum time.


    Sample Input

    3 3
    2 1 1
    1 1 0
    1 1 3
    8 4
    2 1 1 0 1 1 1 0
    1 0 4 1 1 0 4 1
    1 0 0 0 0 0 0 1
    1 1 1 4 1 1 1 3
    8 5
    1 2 1 1 1 1 1 4
    1 0 0 0 1 0 0 1
    1 4 1 0 1 1 0 1
    1 0 0 0 0 3 0 1
    1 1 4 1 1 1 1 1
    8 7
    1 2 1 1 1 1 1 1
    1 1 1 1 1 1 1 4
    1 1 1 1 1 1 1 1
    1 1 1 1 4 1 1 1
    4 1 1 1 1 1 1 1
    1 1 1 1 1 1 1 1
    1 1 1 1 1 1 1 3
    8 8
    1 1 1 1 1 1 1 1
    1 1 1 1 1 1 1 1
    1 1 1 1 1 1 1 1
    1 4 4 1 1 1 1 1
    1 4 4 2 1 1 0 0
    1 1 0 0 0 0 0 3
    1 1 0 4 1 1 1 1
    1 1 1 1 1 1 1 1
    8 8
    1 1 1 1 1 1 1 1
    1 1 2 1 1 1 1 1
    1 1 4 4 4 1 1 1
    1 1 1 4 4 1 0 1
    1 1 1 1 1 1 0 1
    1 1 1 1 1 1 0 3
    1 1 1 1 1 1 1 1
    1 1 1 1 1 1 1 1
    0 0


    Sample Output

    4
    -1
    13
    20
    -1
    -1

     

    /*蚂蚁在2,家在3,4是食物刚开始是hp=6,走一步hp-1,吃过食物之后hp=6,但是到家的时候
    hp=0失败,到食物的时候hp=0也失败,失败之后输出-1,bfs查找*/
    #include<stdio.h>
    #include<string.h>
    #include<queue>
    using namespace std;
    int map[1010][1010];
    int dx[4]={1,0,0,-1};
    int dy[4]={0,1,-1,0};
    int x,y,ex,ey,m,n;
    struct node 
    {
    	int x,y;
    	int hp;
    	int time;
    }p,temp;
    bool judge(node s)
    {
    	if(s.x<0||s.x>=n||s.y<0||s.y>=m)
    	return 1;
    	if(map[s.x][s.y]==0)/*不能越界,不能是墙*/
    	return 1;
    	return 0;
    }
    int bfs()
    {
    	queue<node>q;
    	while(!q.empty()) q.pop();
    	p.x=x;
    	p.y=y;
    	p.time=0;
    	p.hp=6;
    	q.push(p);
    	//vis[x][y]=1;/*不需要标记,每一步走过之后还可以走回来,但是食物只能吃一次*/
    	while(!q.empty())
    	{
    		p=q.front();
    		q.pop();
    		if(p.hp==0) continue;/*到家的时候hp不能等于零*/
    		if(map[p.x][p.y]==3)
    		return p.time;
    		for(int i=0;i<4;i++)
    		{
    			temp.x=p.x+dx[i];
    			temp.y=p.y+dy[i];
    			temp.time=p.time+1;
    			if(judge(temp))
    			continue;
    			temp.hp=p.hp-1;/*每走一步时间加一,hp-1*/
    			if(map[temp.x][temp.y]==4&&temp.hp)
    			{
    				temp.hp=6;
    				map[temp.x][temp.y]=1;/*吃过之后标记,表示为路*/
    			}
    			//vis[temp.x][temp.y]=1;
    			q.push(temp);
    		}
    	}
    	return -1;
    }
    int main()
    {
    	while(scanf("%d%d",&m,&n),m|n)
    	{
    		for(int i=0;i<n;i++)
    		for(int j=0;j<m;j++)
    		{
    			scanf("%d",&map[i][j]);
    			if(map[i][j]==2)
    			{
    				x=i;y=j;
    			}
    			/*if(map[i][j]==3)
    			{
    				ex=i;ey=j;
    			}*/
    		}
    		/*for(int i=0;i<n;i++)
    		{
    			for(int j=0;j<m;j++)
    			printf("%d ",map[i][j]);
    			printf("
    ");
    		}*/
    		int num =bfs();
    		printf("%d
    ",num);
    	}
    	return 0;
    }

  • 相关阅读:
    flutter项目目录介绍
    flutter真机调试出现flutter Launching 'app' on No Devices.
    flutter run出现 Deprecated Gradle features were used in this build, making it incompatible with Gradle 7.0.
    小程序uni-app中uview中select选择器第二次无法选中设置的默认值
    android studio编译flutter项目
    如何解决:Android Studio (version 4.1); Flutter plugin not installed and Dart plugin not installed errors
    CF Round 87
    CF #643(div.2)
    CF #642(div.3)
    CF #638(div.2)
  • 原文地址:https://www.cnblogs.com/playboy307/p/5273853.html
Copyright © 2020-2023  润新知