题意:

      讲的是一个游戏,就是在一个平面上滚动一个1*1*2的长方体的游戏,在本题里面的游戏规则是这样的:

(1)

     一开始给你箱子的状态,可能是横着也可能是竖着。

(2)

     每一次可以滚动箱子,但是每次滚动到的位置(1个或者2个)都必须不能是空的。

(3)

     有的位置只能经得起箱子一半的重量,有的能经得起真个箱子的重量,经得起一半的格子意思就是不能在当前的这个格子上吧箱子竖起来。

(4)然后问从起始状态到掉到终点给的洞里面的最小步数,掉到洞里面的时候必须是竖直掉下去的。



思路:

      比较明显可以用搜索来做,但是这个题目的关键点是如何标记状态,我的做法是对于每一个点都有五个状态,就是另一个点相对于这个点的位置,可以是东南西北,还有正上方

,标记的时候是这样的依靠五个状态,搜索的时候为了简化代码我写的是3个状态的,因为有一些等效状态,我们只要搜索其中的一个就行了,但是如果你愿意把所有的状态都写出来,那么一共是5种,每种有四个方向的走法一共是5*4种选择,这样代码量估计比较大,如果是相等状态只进一个的话可以达到3*4种选择,但是这样的话要注意就是在mark的时候的一些细节,别的没啥的就是简单广搜,姿势好点应该没啥大问题,具体细节可以看下面代码。

#include<queue>

#include<stdio.h>

#include<string.h>

using namespace std;

typedef struct

{

    int x ,y ,t ,k;

}NODE;

NODE xin ,tou;

int map[505][505] ,n ,m;

int mark[505][505][5];

int ex ,ey;

bool ok(int x ,int y ,int k)

{

    return x >= 1 && x <= n && y >= 1 && y <= m && map[x][y] && !mark[x][y][k];

}

int BFS()

{

    queue<NODE>q;

    q.push(xin);

    memset(mark ,0 ,sizeof(mark));

    mark[xin.x][xin.y][xin.k] = 1;

    NODE X1 ,X2;

    while(!q.empty())

    {

        tou = q.front();

        q.pop();

        //printf("%d %d %d %d**\n" ,tou.x ,tou.y ,tou.k ,tou.t);

        if(!tou.k && tou.x == ex && tou.y == ey)

        return tou.t;

        if(tou.k == 0)

        {

            //上

            X1.x = tou.x - 1 ,X1.y = tou.y ,X1.k = 1;

            X2.x = tou.x - 2 ,X2.y = tou.y ,X2.k = 3;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X1.t = tou.t + 1;

                q.push(X1);

            }

            //下

            X1.x = tou.x + 1 ,X1.y = tou.y ,X1.k = 3;

            X2.x = tou.x + 2 ,X2.y = tou.y ,X2.k = 1;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X2.t = tou.t + 1;

                q.push(X2);

            }

            //左

            X1.x = tou.x ,X1.y = tou.y - 1 ,X1.k = 4;

            X2.x = tou.x ,X2.y = tou.y - 2 ,X2.k = 2;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X1.t = tou.t + 1;

                q.push(X1);

            }

            //右

            X1.x = tou.x ,X1.y = tou.y + 1 ,X1.k = 2;

            X2.x = tou.x ,X2.y = tou.y + 2 ,X2.k = 4;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X2.t = tou.t + 1;

                q.push(X2);

            }

        }

        else if(tou.k == 1)

        {

            //上

            X1.x = tou.x - 2 ,X1.y = tou.y ,X1.k = 0;

            if(ok(X1.x ,X1.y ,X1.k) && map[X1.x][X1.y] == 1)

            {

                X1.t = tou.t + 1;

                mark[X1.x][X1.y][X1.k] = 1;

                q.push(X1);

            }

            //下

            X1.x = tou.x + 1 ,X1.y = tou.y ,X1.k = 0;

            if(ok(X1.x ,X1.y ,X1.k) && map[X1.x][X1.y] == 1)

            {

                X1.t = tou.t + 1;

                mark[X1.x][X1.y][X1.k] = 1;

                q.push(X1);

            }

            //左

            X1.x = tou.x ,X1.y = tou.y - 1 ,X1.k = 1;

            X2.x = tou.x - 1 ,X2.y = tou.y - 1 ,X2.k = 3;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X1.t = tou.t + 1;

                q.push(X1);

            }

            //右

            X1.x = tou.x ,X1.y = tou.y + 1 ,X1.k = 1;

            X2.x = tou.x - 1 ,X2.y = tou.y + 1 ,X2.k = 3;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X1.t = tou.t + 1;

                q.push(X1);

            }

        }

        else if(tou.k == 4)

        {

            //上

            X1.x = tou.x - 1 ,X1.y = tou.y ,X1.k = 4;

            X2.x = tou.x - 1 ,X2.y = tou.y - 1 ,X2.k = 2;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X1.t = tou.t + 1;

                q.push(X1);

            }

            //下

            X1.x = tou.x + 1 ,X1.y = tou.y ,X1.k = 4;

            X2.x = tou.x + 1 ,X2.y = tou.y - 1 ,X2.k = 2;

            if(ok(X1.x ,X1.y ,X1.k) && ok(X2.x ,X2.y ,X2.k))

            {

                mark[X1.x][X1.y][X1.k] = mark[X2.x][X2.y][X2.k] = 1;

                X1.t = tou.t + 1;

                q.push(X1);

            }

            //左

            X1.x = tou.x ,X1.y = tou.y - 2 ,X1.k = 0;

            if(ok(X1.x ,X1.y ,X1.k) && map[X1.x][X1.y] == 1)

            {

                X1.t = tou.t + 1;

                mark[X1.x][X1.y][X1.k] = 1;

                q.push(X1);

            }

            //右

            X1.x = tou.x ,X1.y = tou.y + 1 ,X1.k = 0;

            if(ok(X1.x ,X1.y ,X1.k) && map[X1.x][X1.y] == 1)

            {

                X1.t = tou.t + 1;

                mark[X1.x][X1.y][X1.k] = 1;

                q.push(X1);

            }

        }

    }

    return -1;

}

int main ()

{

    char str[505];

    int sx1 ,sx2 ,sy1 ,sy2 ,s;

    while(~scanf("%d %d" ,&n ,&m) && n + m)

    {

        s = 0;

        for(int i = 1 ;i <= n ;i ++)

        {

            scanf("%s" ,str);

            for(int j = 1 ;j <= m ;j ++)

            {

                if(str[j-1] == 'X')

                {

                    s ++;

                    if(s == 1) sx1 = i ,sy1 = j;

                    else sx2 = i ,sy2 = j;

                    map[i][j] = 1;

                }

                else if(str[j-1] == 'O')

                {

                    ex = i ,ey = j;

                    map[i][j] = 1;

                }

                else if(str[j-1] == 'E') map[i][j] = 2;

                else if(str[j-1] == '#') map[i][j] = 0;

                else map[i][j] = 1;

            }

        }

        if(s == 1) xin.x = sx1 ,xin.y = sy1 ,xin.k = 0 ,xin.t = 0;

        else

        {

            if(sx1 == sx2) xin.x = sx2 ,xin.y = sy2 ,xin.k = 4 ,xin.t = 0;

            else xin.x = xin.x = sx2 ,xin.y = sy2 ,xin.k = 1 ,xin.t = 0;

        }

        int ans = BFS();

        ans == -1 ? printf("Impossible\n") : printf("%d\n" ,ans);

    }

    return 0;

}

POJ3322滚箱子游戏(不错)的更多相关文章

  1. Unity3D游戏开发初探—4.开发一个“疯狂击箱子”游戏

    一.预备知识—对象的”生“与”死“ (1)如何在游戏脚本程序中创建对象而不是一开始就创建好对象?->使用GameObject的静态方法:CreatePrimitive() 以上一篇的博文中的“指 ...

  2. JavaScript写一个小乌龟推箱子游戏

    推箱子游戏是老游戏了, 网上有各种各样的版本, 说下推箱子游戏的简单实现,以及我找到的一些参考视频和实例: 推箱子游戏的在线DEMO : 打开 如下是效果图: 这个拖箱子游戏做了移动端的适配, 我使用 ...

  3. 用HTML5+原生js实现的推箱子游戏

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. C# 推箱子游戏&对战游戏

    推箱子游戏提纲,只有向右向上的操作,向左向下同理,后期需完善. namespace 推箱子 { class Program { static void Main(string[] args) { // ...

  5. C++学习(九)(C语言部分)之 项目 推箱子游戏

    游戏制作 推箱子 步骤分析 1.模板 2.模板分析 组成元素: 空地 墙 人 目的地 箱子 背景 3.如何操作 通过WASD键盘操作人,推着箱子,到达目的地,游戏结束,如果箱子卡在死角则游戏失败 4. ...

  6. 【CCpp程序设计2017】推箱子游戏

    我的还……支持撤销!用链表实现! 题目:推箱子小游戏(基于console) 功能要求: 将p09迷宫游戏改造为“推箱子”游戏: 在地图中增加箱子.箱子目标位置等图形: 当玩家将所有箱子归位,则显示玩家 ...

  7. JavaScript 推箱子游戏

    推箱子游戏的 逻辑非常简单,但是如果不动手的话,还是不太清楚.我在这里讲一下自己的思路. 制作推箱子,首先要有自己的设计素材.如下我也是网上找的素材 第二步,理清游戏的规则. 游戏规则: 1.小人将箱 ...

  8. three.js 制作一个三维的推箱子游戏

    今天郭先生发现大家更喜欢看我发的three.js小作品,今天我就发一个3d版本推箱子的游戏,其实webGL有很多框架,three.js并不合适做游戏引擎,但是可以尝试一些小游戏.在线案例请点击博客原文 ...

  9. 用C写一个简单的推箱子游戏(二)

    下面接着上一篇随笔<用C写一个简单的推箱子游戏(一)>来写 tuidong()函数是用来判断游戏人物前方情况的函数,是推箱子游戏中非常重要的一个函数,下面从它开始继续介绍推箱子的小程序怎么 ...

随机推荐

  1. Java 集合框架 04

    集合框架·Map 和 Collections集合工具类 Map集合的概述和特点 * A:Map接口概述 * 查看API可知: * 将键映射到值的对象 * 一个映射不能包含重复的键 * 每个键最多只能映 ...

  2. 面试官:不会sql优化?出门右转顺便带上门,谢谢

    导读 作为一个后端程序员,数据库这个东西是绕不开的,特别是写sql的能力,如果您参加过多次面试,那么一定会从面试复盘中发现面试官总是会考察到sql优化这个东西. 我在之前的多次面试中最常遇到的一个问题 ...

  3. windows基线检测脚本编写指南-powershell版

    前言:   因为工作的原因,要写windows下的基线检查脚本.之前没接触过,在网上找了半天也没找到现成的,无奈只好自己研究,最后还是成功完成了工作. 在我编写之后发现windows下的基线基本就是检 ...

  4. 如何使用python把json文件转换为csv文件

    @ 目录 了解json整体格式 转换格式 提取key和value 使用pandas写入csv 了解json整体格式 这里有一段json格式的文件,存着全球陆地和海洋的每年异常气温(这里只选了一部分): ...

  5. JetBrains Projector 体验

    先来一张最终效果图: JetBrains Projector 是 JetBrains 的"远程开发"解决方案,基于 Client + Server 架构,对标的是微软 VSCode ...

  6. certutil绕过

    一般进内网过后我都会使用certutil下载文件,但在最近打一台内网机子的时候出现了certutil拒绝访问的情况,在本地搭建了一个环境尝试绕过certutil下载文件. 安装杀软更新到最新版本,开启 ...

  7. pytest进阶之fixture函数

    fixture函数存在意义 与python自带的unitest测试框架中的setup.teardown类似,pytest提供了fixture函数用以在测试执行前和执行后进行必要的准备和清理工作.但是相 ...

  8. Python基础之:Python中的异常和错误

    目录 简介 Python中的内置异常类 语法错误 异常 异常处理 抛出异常 异常链 自定义异常 finally 简介 和其他的语言一样,Python中也有异常和错误.在 Python 中,所有异常都是 ...

  9. java例题_34 用指正对三个数排序

    1 /*34 [程序 34 三个数排序] 2 题目:输入 3 个数 a,b,c,按大小顺序输出. 3 程序分析:利用指针方法. 4 */ 5 6 /*分析 7 * 指针方法的本质是按地址传值,将a,b ...

  10. Java基础回顾_第一部分

    Java基础回顾 基本数据类型 数值类型 什么是字节? 位(bit):是计算机中数据的最小单位 字节(byte):是计算机中数据处理的基本单位,习惯上用大写字母B来表示 1 B = 8 bit 字符: ...