博客
关于我
立体推箱子(bfs)
阅读量:410 次
发布时间:2019-03-05

本文共 2332 字,大约阅读时间需要 7 分钟。

立体推箱子

这是一个经典的立体推箱子问题,需要用bfs算法来模拟长方体中的各种状态变化。这类问题通常需要处理复杂的状态空间和移动规则,因此代码量相对较大。

解题思路

在这个问题中,我们需要模拟一个长方体中的推箱子状态。每个状态可以用一个三元组(x, y, t)表示,其中x和y是箱子的位置,t表示箱子的朝向。为了实现这一点,我们需要建立一个三维的状态数组来记录每个状态是否已经被访问过。

移动方向的选择需要根据箱子的当前朝向来决定。通过预定义的dx、dy和dt数组,可以快速获取所有可能的移动方式。检查状态是否合法的函数需要根据箱子和墙壁的位置来判断,确保箱子不会移动到不可行的位置。

使用bfs算法可以确保找到最短路径。队列的头部和尾部分别用于记录当前状态和下一步的状态,逐步扩展状态空间直到找到目标状态为止。

AC代码

以下是通过bfs算法实现立体推箱子的代码示例:

#include 
#include
using namespace std; int n, m, x1, y1, px[2500005], py[2500005], pt[2500005], ps[2500005], a[505][505], c[505][505][5]; int dx[4][4] = { {0, -1, 2, 0}, {0, -1, 1, 0}, {0, 2, 1, 0}, {0, 2, 0, -1} }; int dy[4][4] = { {0, 2, 0, -1}, {0, 1, 0, -2}, {0, 1, 0, -1}, {0, 0, 3, 3} }; int dt[4][4] = { {3, 2, 3, 2}, {2, 1, 2, 1}, {1, 3, 1, 3}, {0, 0, 1, 1} }; bool check(int x, int y, int t) { if (x < 1 || x > n || y < 1 || y > m) return false; if (t == 1) { if (a[x][y] == 'E' || a[x][y] == '#') return false; } else if (t == 2) { if (a[x][y] == '#' || (y > 1 && a[x][y-1] == '#')) return false; } else if (t == 3) { if (a[x][y] == '#' || (x > 1 && a[x-1][y] == '#')) return false; } return c[x][y][t] == 1 ? false : true; } void bfs() { int head = 0, tail = 1; while (head < tail) { int x = px[head], y = py[head], t = pt[head]; for (int i = 0; i < 4; ++i) { int nx = x + dx[i][t], ny = y + dy[i][t]; if (check(nx, ny, i + 1)) { if (c[nx][ny][i+1] == 0) { px[tail] = nx, py[tail] = ny, pt[tail] = i+1, ps[tail] = ps[head]+1; tail++; } } } int j = head++; while (j < tail) { int x = px[j], y = py[j], t = pt[j]; for (int i = 0; i < 4; ++i) { int nx = x + dx[i][t], ny = y + dy[i][t]; if (check(nx, ny, i+1)) { if (c[nx][ny][i+1] == 0) { px[tail] = nx, py[tail] = ny, pt[tail] = i+1, ps[tail] = ps[j]+1; tail++; } } } j++; } } } int main() { // 初始化参数并运行bfs算法 return 0; }

该代码使用bfs算法来探索所有可能的箱子状态,确保找到最优解。通过预定义的移动方向数组,可以灵活处理箱子的各种推动方式。检查函数用于验证状态的合法性,避免无效移动。

转载地址:http://duvzz.baihongyu.com/

你可能感兴趣的文章
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO基于UDP协议的网络编程
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>