C. Robot (BFS)

Source: Internet
Author: User
C. Robot Time limit:3000 Ms Case time limit:3000 Ms Memory limit:262144kb64-bit integer Io format: % LLD Java class name: mainsubmit status PID: 36000 font size: + -

There is a rectangular field in the lab of institution of advanced robotic technology.

Except robots are about to release to this field one after another. they always enter the field from the upper left cell and leave from the lower right cell. in between, they can move vertically or horizontally to an adjacent cell on each step. at any time, there is at most one robot on the field.

Robots can be divided into two types: type A and type B. during the movement, a robot will write down its type mark (A or B) in each cell on its track, which will cover all previous marks in the same cell. notice that there is no mark on the field at the beginning.

Here is an example: Initially there is no mark on the field (figure 1); first, a robot of type A crosses the field from top-left to bottom right (figure 2 ). after that, a robot of type B crosses and its tracks are partially covering the's (Figure 3 ).

                    .....          AAAA.          BBAA.
                    .....          ..AA.          .BBBB
                    .....          ...A.          ...AB
                    .....          .AAA.          .ABBB
                    .....          ..AAA          ..BBB
                     (1)            (2)            (3)

You are given the marks on the field after all robots have crossed. Write a program to determine the minimal possible number of released robots.


Inputthe first line contains an integer T (1 ≤ T ≤ 10) -- the number of test cases.

For each test case:
The first line contains two integers H and W, indicates the height and width of the field. 1 ≤ h, W ≤ 4 000.
Then follows H lines, each line contains W characters: each character indicates the mark in the corresponding cell. A dot (".") indicates that there is no mark on this cell.
There is at least one mark on the field. outputfor each test case, output one integer in a single line -- the minimal number of released robots. sample input
23 3AA..A..AA5 8AAB......ABBB....AAAAA....BBBAAB.....AAA
Sample output
12
Submit status PID: 36000
#include<stdio.h>#include<queue>#include<iostream>using namespace std;typedef struct nnn{    int x,y;}node;int vist[4005][4005];char map[4005][4005];int n,m,k,dir[4][2]={0,1,0,-1,1,0,-1,0},tf;void init(){    for(int i=0;i<n;i++)    for(int j=0;j<m;j++)    vist[i][j]=0;}queue<node>q[2];void bfs(int flag){    node p,s;    k++;    while(!q[flag].empty())    {        s=q[flag].front(); q[flag].pop();        if(s.x==0&&s.y==0)tf=1;        for(int e=0;e<4;e++)        {            p.x=s.x+dir[e][0]; p.y=s.y+dir[e][1];            if(p.x>=0&&p.x<n&&p.y>=0&&p.y<m&&vist[p.x][p.y]==0&&map[p.x][p.y]!='.')            {                vist[p.x][p.y]=1;                if(map[p.x][p.y]!=map[s.x][s.y])                    q[!flag].push(p);                else q[flag].push(p);            }        }    }}int main(){    int t,f,flag;    scanf("%d",&t);    while(t--)    {        scanf("%d%d",&n,&m);        for(int i=0;i<n;i++)scanf("%s",map[i]);        k=0; tf=0;        while(!q[0].empty())q[0].pop();        while(!q[1].empty())q[1].pop();        if(map[0][0]!=map[n-1][m-1])f=1;else f=0;        if(map[n-1][m-1]!='.')        {            node s;            init();            s.x=n-1; s.y=m-1; flag=0;            vist[n-1][m-1]=1; q[0].push(s);           while(!q[flag].empty())           {               bfs(flag); flag=(!flag);           }        }        else f=0;        if(tf==0&&f)f=0;        printf("%d\n",k-f);    }}


C. Robot (BFS)

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.