hdu 2102 A计划 队列

刚开始错了好几次后来改了一下,居然又是内存超限。半个小时后才明白刚开始为什么错了和为什么会有内存超限,仅仅是赋值时将=写成 了==,好大的教训。刚开始没有开数组记录访问情况时,以为将.和#全部变成了*,居然忘记了将P也变成了墙,导致多花费了这么多时间。不要忘记今天的教训。

/* *********************************************** Author :xryz Email :[email protected] Created Time :2015-4-10 10:48:21 File Name :\A.CPP ************************************************ */

#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
#include <set>
#include <map>
#include <string>
#include <math.h>
#include <stdlib.h>
#include <time.h>
using namespace std;

struct node
{
    int x,y,c,t;
}a,a0;

int n,m,tme;
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
char s[2][15][15];

int bfs()
{
    int i;
    queue<node>q;
    a.c=0,a.x=1,a.y=1,a.t=0;
    q.push(a);
    while(!q.empty())
    {
        a0=q.front();
        q.pop();
        if(a0.t>tme) break;
        if(s[a0.c][a0.x][a0.y]=='P') return 1;
        for(i=0;i<4;i++)
        {
            a.x=a0.x+dx[i];
            a.y=a0.y+dy[i];
            a.t=a0.t+1;
            a.c=a0.c;
            if(a.x<1||a.y<1||a.x>n||a.y>m||s[a.c][a.x][a.y]=='*') continue;
            if(s[a.c][a.x][a.y]=='#') 
            {
                s[a.c][a.x][a.y]='*';
                if(a.c==0) a.c=1;
                    else a.c=0;
            }
            //if(s[a.c][a.x][a.y]=='P');
            q.push(a);
            if(s[a.c][a.x][a.y]!='P') s[a.c][a.x][a.y]='*';
            //不要将公主变成墙了
        }
    }
    return 0;
}
/* *********************************************** Author :xryz Email :[email protected] Created Time :2015-4-10 10:48:21 File Name :\A.CPP ************************************************ */

#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
#include <set>
#include <map>
#include <string>
#include <math.h>
#include <stdlib.h>
#include <time.h>
using namespace std;

struct node
{
    int x,y,c,t;
}a,a0;

int n,m,tme;
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
char s[2][15][15];
int vis[2][15][15];

int bfs()
{
    int i;
    queue<node>q;
    a.c=0,a.x=1,a.y=1,a.t=0;
    vis[0][1][1]=1;
    s[a.c][a.x][a.y]='*';
    q.push(a);
    while(!q.empty())
    {
        a0=q.front();
        q.pop();
        if(a0.t>tme) break;
        if(s[a0.c][a0.x][a0.y]=='P') return 1;
        for(i=0;i<4;i++)
        {
            a.x=a0.x+dx[i];
            a.y=a0.y+dy[i];
            a.c=a0.c;
            a.t=a0.t+1;
            if(a.x<1||a.y<1||a.x>n||a.y>m||s[a.c][a.x][a.y]=='*'||vis[a.c][a.x][a.y]) continue;
            if(s[a.c][a.x][a.y]=='#'&&vis[a.c][a.x][a.y]==0) {vis[a.c][a.x][a.y]=1;a.c=!a.c;}
            q.push(a);
            //printf("%d %d %d %c\n",a.c,a.x,a.y,s[a.c][a.x][a.y]);
            vis[a.c][a.x][a.y]=1;

        }
    }
    return 0;
}

int main()
{
    int i,j,cas,k;
    scanf("%d",&cas);
    while(cas--)
    {
        memset(s,0,sizeof(0));
        scanf("%d%d%d",&n,&m,&tme);

        for(k=0;k<=1;k++)
            for(i=1;i<=n;i++)
                for(j=1;j<=m;j++)
                    cin>>s[k][i][j];
        memset(vis,0,sizeof(vis));  
        for(i=1;i<=n;i++)
            for(j=1;j<=n;j++)
            {
                if(s[0][i][j]=='#'&&s[1][i][j]=='*') s[0][i][j]='*';
                if(s[1][i][j]=='#'&&s[0][i][j]=='*') s[1][i][j]='*';
                if(s[1][i][j]=='#'&&s[0][i][j]=='#') s[1][i][j]=s[0][i][j]='*';
            }

        if(bfs()) printf("YES\n");
        else printf("NO\n");
    }
    return 0;
}

你可能感兴趣的:(hdu 2102 A计划 队列)