Seven Puzzle Aizu
来源:互联网 发布:深圳市历年gdp数据 编辑:程序博客网 时间:2024/05/20 03:05
题意:这题应该算是经典的八数码问题的弱化版吧:给你一个4x2的方版,上面有0-7 八个数字,每次只能让编号0的方格跟他的上下左右的方格交换;所以也就是把方格0当做空格看待,每次只有空格周围的方格能够向空格处移动。 然后问从输入的方格样式变换到字典序最小的"01234567" 最少需要多少次.
思路:反向BFS。
AC代码:
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <queue>
#include <cmath>
#include <map>
#include <algorithm>
#include <stack>
#include <set>
//反向bfs
using namespace std;
map<string ,int> t;
int num;
int mv[]={-4,4,1,-1};//上下右左
void bfs(string st)
{
queue<string> q;
t[st]=1;
q.push(st);
while(!q.empty())
{
st=q.front(),q.pop();
int num=st.find('0');
for(int i=0;i<4;++i)
{
int tn=num+mv[i];
if(tn<0||tn>7||num==3&&mv[i]==1||num==4&&mv[i]==-1)
continue;
string tp=st;
swap(tp[num],tp[num+mv[i]]);
if(!t[tp])
{
q.push(tp);
t[tp]=t[st]+1;
}
}
}
}
int main()
{
string st="01234567";
bfs(st);//反向BFS
while(scanf("%d",&num)!=EOF)
{
st[0]=num+'0';
for(int i=1;i<8;i++)
{
scanf("%d",&num);
st[i]=num+'0';
}
cout<<t[st]-1<<endl;
}
}
- Aizu 0121 Seven Puzzle
- Seven Puzzle Aizu
- Seven Puzzle Aizu
- Seven Puzzle (Aizu 0121 反向搜索bfs)
- AOJ 0121 Seven Puzzle
- AOJ--0121 Seven Puzzle
- Seven Puzzle (AOJ 0121 bfs)
- Aoj 0121 Seven Puzzle【bfs】
- ACM Seven Puzzle(挑战程序设计竞赛)
- [挑战程序设计竞赛] AOJ 0121 - Seven Puzzle
- AOJ 0121 Seven Puzzle (bfs)
- 搜索 Seven Puzzle (AOJ 0121 bfs)
- AOJ 0121:Seven Puzzle(bfs)
- Seven Puzzle AOJ 0121宽度优先搜索
- AOJ0121——Seven Puzzle(BFS)
- AOJ 0121: Seven Puzzle (BFS DP STL 逆向推理)
- AOJ 0121: Seven Puzzle (BFS DP STL 逆向推理)
- G - Seven Puzzle(7宫格)AOJ 0121
- 微信小程序周报(第十三期)-极乐商店(store.dreawer.com)出品
- Docs » Logs » Downloading and Analyzing Data Logs in Mission Planner
- 基于DateTime.ParseExact方法的使用详解
- 计算机图形学(二)
- [PHP学习]TP5学习之Apache服务器隐藏index.php入口文件
- Seven Puzzle Aizu
- 队列小练习
- 图形与图像编程(四)-图像特效
- C++服务器程序崩溃的调试办法
- leetcode-最接近0的子数组和
- java中自动装箱拆箱的陷阱
- block
- 深度神经网络可视化工具
- 404错误处理进阶