BZOJ-3338: Zju1505 Solitaire(双向BFS)

题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3338

被Source剧透了真不爽。。。话说这么一道水BFS居然能让我调上一天。。。我实在还是太弱了。。。

判重:把棋盘8*8=64压成一个64无符号位整型,然后就直接set好了。。。话说打Hash不是更快?懒呗~

代码:

8ad4b31c8701a18b756007339c2f07082938fec7.jpg.png
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <queue>
#include <set>
 
using namespace std ;
 
#define ULL unsigned long long 
#define check( x , y ) ( x > 0 && x < 9 && y > 0 && y < 9 )
 
struct node {
    int p[ 4 ][ 2 ] , dist ;
    bool flag ;
};
 
queue < node > Q ;
 
set < ULL > s0 ,s1 ;
 
ULL Exp[ 64 ] ;
 
ULL Hash( node x ) {
    ULL rec = 0 ;
    for ( int i = 0 ; i < 4 ; i ++ ) rec += Exp[ 8 * ( x.p[ i ][ 0 ] - 1 ) + x.p[ i ][ 1 ] - 1 ] ;
    return rec ;
}
 
node S , T ;
 
const int dir[ 4 ][ 2 ] = { { - 1 , 0 } , { 1 , 0 } , { 0 , - 1 } , { 0 , 1 } } ;
 
bool Check( int x , int y , node u ) {
    for ( int i = 0 ; i < 4 ; i ++ ) if ( u.p[ i ][ 0 ] == x && u.p[ i ][ 1 ] == y ) return false ;
    return true ;
}
 
bool bfs(  ) {
    while ( ! Q.empty(  ) ) Q.pop(  ) ;
    s0.insert( Hash( S ) ) , s1.insert( Hash( T ) ) ; Q.push( S ) , Q.push( T ) ;
    while ( ! Q.empty(  ) ) {
        node v = Q.front(  ) ; Q.pop(  ) ;
        for ( int i = 0 ; i < 4 ; i ++ ) for ( int j = 0 ; j < 4 ; j ++ ) {
            int x = v.p[ i ][ 0 ] + dir[ j ][ 0 ] , y = v.p[ i ][ 1 ] + dir[ j ][ 1 ] ;
            if ( ! check( x , y ) ) continue ;
            if ( ! Check( x , y , v ) ) x += dir[ j ][ 0 ] , y += dir[ j ][ 1 ] ;
            if ( ( ! check( x , y ) ) || ( ! Check( x , y , v ) ) ) continue ;
            node u = v ;
            u.p[ i ][ 0 ] = x , u.p[ i ][ 1 ] = y , u.dist ++ ;
            ULL w = Hash( u ) ;
            if ( s0.find( w ) != s0.end(  ) ) {
                if ( u.flag ) return true ;
                continue ;
            }
            if ( s1.find( w ) != s1.end(  ) ) {
                if ( ! u.flag ) return true ; 
                continue ;
            }
            if ( u.flag ) s1.insert( w ) ; else s0.insert( w ) ;
            if ( u.dist >= 4 ) continue ;
            Q.push( u ) ;
        }
    }
    return false ;
}
 
int main(  ) {
    Exp[ 0 ] = 1 ; for ( int i = 1 ; i < 64 ; i ++ ) Exp[ i ] = Exp[ i - 1 ] * 2 ;
    while ( scanf( "%d%d" , &S.p[ 0 ][ 0 ] , &S.p[ 0 ][ 1 ] ) != EOF ) {
        s0.clear(  ) , s1.clear(  ) ;
        for ( int i = 1 ; i < 4 ; i ++ ) scanf( "%d%d" , &S.p[ i ][ 0 ] , &S.p[ i ][ 1 ] ) ;
        for ( int i = 0 ; i < 4 ; i ++ ) scanf( "%d%d" , &T.p[ i ][ 0 ] , &T.p[ i ][ 1 ] ) ;
        S.dist = T.dist = 0 ; S.flag = 0 , T.flag = 1 ;
        printf( bfs(  ) ? "YES\n" : "NO\n" ) ;
    }
    return 0 ;
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,976评论 6 513
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,249评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,449评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,433评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,460评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,132评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,721评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,641评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,180评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,267评论 3 339
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,408评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,076评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,767评论 3 332
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,255评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,386评论 1 271
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,764评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,413评论 2 358

推荐阅读更多精彩内容