Thursday, 1 June 2017

UVA 10653 - Bombs! NO they are Mines!!

Problem Link:https://uva.onlinejudge.org/index.php?option=onlinejudge&page=show_problem&problem=1594

Bombs! NO they are Mines!!
Input: standard input
Output: standard output
Time Limit: 4 seconds

It's the year 3002. The robots of "ROBOTS 'R US (R:US)" have taken control over the world. You are one of the few people who remain alive only to act as their guinea pigs. From time to time the robots use you to find if they have been able to become more intelligent. You, being the smart guy, have always been successful in proving to be more intelligent.
Today is your big day. If you can beat the fastest robot in the IRQ2003 land, you'd be free. These robots are intelligent. However, they have not been able to overcome a major deficiency in their physical design -- they can only move in 4 directions: Forward, Backward, Upward and Downward. And they take 1 unit time to travel 1 unit distance. As you have got only one chance, you're planning it thoroughly. The robots have left one of the fastest robot to guard you. You'd need to program another robot which would carry you through the rugged terrain. A crucial part of your plan requires you to find the how much time the guard robot would need to reach your destination. If you can beat him, you're through.
 
We must warn you that the IRQ2003 land is not a pleasant place to roam. The R:US have dropped numerous bombs while they invaded the human land. Most of the bombs have exploded. Still some of the bombs remain acting as land mines. We have managed to get a map that shows the unsafe regions of the IRQ2003 land; unfortunately your guard has a copy of the map, too. We know that at most 40% of the area can be unsafe. If you are to beat your guard, you'd have to find his fastest route long before he finds it.
Input
Input consists of several test cases. Each test begins with two integers R (1 <= R <= 1000), C (1 <= C <= 1000) -- they give you the total number of rows and columns in the grid map of the land. Then follows the grid locations of the bombs. It starts with the number of rows, (0 <= rows <= R) containing bombs. For each of the rows, you'd have one line of input. These lines start with the row number, followed by the number of bombs in that row. Then you'd have the column locations of that many bombs in that row. The test case ends with the starting location (row, column) followed by your destination (row, column). All the points in the region is in the range (0,0) to (R-1, C-1). Input ends with a test case where R=0 and C=0, you must not process this test case.
Output
For each test case, print the time the guard robot would take to go from the starting location to the destination.
Sample Input                           Output for Sample Input
10 10
9
0 1 2
1 1 2
2 2 2 9
3 2 1 7
5 3 3 6 9
6 4 0 1 2 7
7 3 0 3 8
8 2 7 9
9 3 2 3 4
0 0
9 9
0 0 18

My accepted code is given below:
#include<bits/stdc++.h>
using namespace std;
long long n,m,sx,sy,ex,ey;
long long ar[1009][1009],visit[1009][1009],cost[1009][1009];
long long br[]= {1,-1,0,0};
long long cr[]= {0,0,1,-1};
int bsf(int x,int y)
{
    queue<long long>q;
    memset(visit,0,sizeof visit);
    memset(cost,0,sizeof cost);
    long long fx,fy,i,j,vx,vy,f;
    q.push(x);
    q.push(y);
    visit[x][y]=1;
    cost[x][y]=0;
    //cout<<"f"<<endl;
    while(!q.empty())
    {
        fx=q.front();
        q.pop();
        fy=q.front();
        q.pop();
        f=0;
        //cout<<fx<<" "<<fy<<endl;
        for(i=0; i<4; i++)
        {
            vx=fx+br[i];
            vy=fy+cr[i];
            if(vx>=0&&vx<n&&vy>=0&&vy<m&&ar[vx][vy]!=1)
            {
                if(visit[vx][vy]==0)
                {
                    q.push(vx);
                    q.push(vy);
                    visit[vx][vy]=1;
                    cost[vx][vy]=cost[fx][fy]+1;
                    //cout<<vx<<" "<<vy<<" "<<cost[vx][vy]<<endl;
                }
            }
            if(vx==ex&&vy==ey)
            {
                cout<<cost[vx][vy]<<endl;
                f=1;
                break;
            }
        }
        if(f==1)
            break;
    }
}
int main()
{
    long long i,j,t,a,b,x;
    while(cin>>n>>m)
    {
        if(n==0&&m==0)
            break;
            //cout<<"test"<<endl;
        cin>>t;
        memset(ar,0,sizeof ar);
        for(i=0; i<t; i++)
        {
           // cout<<"t="<<i<<endl;
            cin>>a>>x;
            for(j=0; j<x; j++)
            {
                cin>>b;
                ar[a][b]=1;
            }

        }
        cin>>sx>>sy>>ex>>ey;
        bsf(sx,sy);
    }
    return 0;
}
/*
1 0 1
0 1 1
2 0 2
1 1 2
3 0 3
2 1 3
4 0 4
5 0 5
4 1 5
5 1 6
4 2 6
5 2 7
3 2 7
4 3 7
3 3 8
4 4 8
2 3 9
3 4 9
5 4 9
4 5 9
1 3 10
2 4 10
3 5 10
6 4 10
5 5 10
4 6 10
0 3 11
1 4 11
2 5 11
3 6 11
7 4 11
6 5 11
6 3 11
4 7 11
0 4 12
1 5 12
2 6 12
8 4 12
7 5 12
6 6 12
5 7 12
4 8 12
0 5 13
1 6 13
2 7 13
8 5 13
8 3 13
7 6 13
5 8 13
3 8 13
4 9 13
0 6 14
1 7 14
2 8 14
9 5 14
8 6 14
8 2 14
7 7 14
6 8 14
3 9 14
0 7 15
1 8 15
9 6 15
7 2 15
8 1 15
6 9 15
0 8 16
1 9 16
9 7 16
7 1 16
9 1 16
8 0 16
7 9 16
0 9 17
9 8 17
9 0 17
8 8 18
9 9 18
ans=17
*/

1 comment:

  1. Whether you're bringing home an older dog or training a younger one, Samoyed Dog Breed can help you with the transition. Fortunately, this new toy is not only entertaining but also helps train your pet.

    ReplyDelete