码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 1753

时间:2015-06-10 17:08:09      阅读:92      评论:0      收藏:0      [点我收藏+]

标签:

#include <iostream>
#include <queue>
using namespace std;

char _m[4][4];
bool mark[100000];

struct node
{
    int step;
    int state;
};

bool BFS(node p);

bool boo;

node t;

void move(int r)//位操作的改变状态~
{        
    t.state^=(1<<(15-r));
    if(r>=4)
          t.state^=(1<<(15-r+4));
    if(r<=11)
          t.state^=(1<<(15-r-4));    
    if((r%4))
          t.state^=(1<<(15-r+1));
    if(((r+1)%4))
          t.state^=(1<<(15-r-1));
}



queue<node> coll;

int main()
{
    //freopen("acm.acm","r",stdin);
    int i;
    int j;
    node begin;
    begin.state = 0;
    begin.step = 0;

    for(i = 0; i < 4; ++ i)
    {
        for(j = 0; j < 4; ++ j)
        {
            cin>>_m[i][j];
            if(_m[i][j] == b)
            {
                begin.state += 1;
            }
            begin.state <<= 1;
        }
        
    }
    begin.state >>= 1;
    memset(mark,false,sizeof(mark));
    if(begin.state == 0 || begin.state == 65535)
    {
        cout<<"0"<<endl;
    }
    else
    {
        coll.push(begin);
        mark[begin.state] = true;
        boo = false;
        while(!coll.empty() && !BFS(coll.front()))
        {
            coll.pop();
        }
        if(!boo)
        {
            cout<<"Impossible"<<endl;
        }
    }

}

bool BFS(node p)
{
//    cout<<p.state<<endl;
    if(p.state == 0 || p.state == 65535)
    {
        boo = true;
        cout<<p.step<<endl;
        return true;
    }
    int i;
    
    for(i = 0; i < 16; ++ i)
    {
        
        t = p;
        move(i);
    //    cout<<t.state<<endl;
        if(!mark[t.state])
        {
            t.step = p.step + 1;
            coll.push(t);
            mark[t.state] = true;
        }
    }

    return false;
}

 

POJ 1753

标签:

原文地址:http://www.cnblogs.com/gavinsp/p/4566534.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!