洛谷—— P1379 八数码难题
https://daniu.luogu.org/problem/show?pid=1379
题目描述
在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字。棋盘中留有一个空格,空格用0来表示。空格周围的棋子可以移到空格中。要求解的问题是:给出一种初始布局(初始状态)和目标布局(为了使题目简单,设目标状态为123804765),找到一种最少步骤的移动方法,实现从初始布局到目标布局的转变。
输入输出格式
输入格式:
输入初始状态,一行九个数字,空格用0表示
输出格式:
只有一行,该行只有一个数字,表示从初始状态到目标状态需要的最少移动次数(测试数据中无特殊无法到达目标状态数据)
输入输出样例
- 283104765
- 4
- BFS搜索每种移动的状态,hash判重
- #include <cstring>
- #include <cstdio>
- #include <queue>
- #define swap(a,b) {int tmp=a; a=b; b=tmp; }
- const int op[][]={{,,},
- {,,},
- {,,}};
- bool vis[];
- struct Checkerboard {
- int step;
- int map[][];
- Checkerboard() { step=; memset(map,,sizeof(map)); }
- } u;
- std::queue<Checkerboard>que;
- int fx[]={,,,-};
- int fy[]={,,-,};
- char s[];
- inline bool print(Checkerboard x)
- {
- for(int i=; i<; ++i)
- for(int j=; j<; ++j)
- if(x.map[i][j]!=op[i][j]) return ;
- return true;
- }
- inline int BFS()
- {
- que.push(u);
- for(Checkerboard v; !que.empty(); )
- {
- v=u=que.front(); que.pop();
- int tmp=,t=,k=;
- for(int i=; i<; ++i)
- for(int j=; j<; ++j)
- tmp+=k*u.map[i][j],t++,k*=t;
- vis[tmp]=;
- if(print(u)) return u.step;
- int x,y;
- for(int i=; i<; ++i)
- for(int j=; j<; ++j)
- if(u.map[i][j]==)
- {
- for(int k=; k<; ++k)
- {
- x=fx[k]+i,y=fy[k]+j;
- if(x>=&&y>=&&x<&&y<)
- {
- v.map[i][j]=v.map[x][y];
- v.map[x][y]=;
- v.step=u.step+;
- int tmp=,t=,k=;
- for(int i=; i<; ++i)
- for(int j=; j<; ++j)
- tmp+=k*v.map[i][j],t++,k*=t;
- if(!vis[tmp])
- vis[tmp]=,que.push(v);
- v=u;
- }
- }
- goto STEP;
- }
- STEP:;
- }
- return ;
- }
- int Presist()
- {
- scanf("%s",s);
- for(int i=; i<; ++i) u.map[][i]=s[i]-'';
- for(int i=; i<; ++i) u.map[][i%]=s[i]-'';
- for(int i=; i<; ++i) u.map[][i%]=s[i]-'';
- printf("%d\n",BFS());
- return ;
- }
- int Aptal=Presist();
- int main(){;}
洛谷—— P1379 八数码难题的更多相关文章
- 洛谷 P1379 八数码难题 解题报告
P1379 八数码难题 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初 ...
- 洛谷——P1379 八数码难题
P1379 八数码难题 双向BFS 原来双向BFS是这样的:终止状态与起始状态同时入队,进行搜索,只不过状态标记不一样而已,本题状态使用map来存储 #include<iostream> ...
- 洛谷P1379八数码难题
题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中. 要求解的问题是:给出一种初始布局(初始状态)和目标布局(为 ...
- 洛谷 P1379 八数码难题 Label:判重&&bfs
特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...
- 洛谷 P1379 八数码难题
题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初始状态)和目标布局(为了 ...
- 洛谷 - P1379 - 八数码难题 - bfs
https://www.luogu.org/problemnew/show/P1379 #include <bits/stdc++.h> using namespace std; #def ...
- 洛谷P1379 八数码难题
传送门 1.先用dfs枚举9!的全排列,存到hash数组里(类似离散化),因为顺序枚举,就不需要排序了 2.朴素bfs,判重就用二分找hash:如果发现当前状态=要求状态,输出步数结束程序 上代码 # ...
- 洛谷 P1379 八数码难题 题解
我个人感觉就是一道bfs的变形,还是对bfs掌握不好的人有一定难度. 本题思路: 大体上用bfs搜,用map来去重,在这里只需要一个队列,因为需要较少步数达到的状态一定在步数较多的状态之前入队列. # ...
- 洛谷 P1379 八数码难题(map && 双向bfs)
题目传送门 解题思路: 一道bfs,本题最难的一点就是如何储存已经被访问过的状态,如果直接开一个bool数组,空间肯定会炸,所以我们要用另一个数据结构存,STL大法好,用map来存,直接AC. AC代 ...
随机推荐
- javaEE框架获取和传参要使用的类和接口
1:spring 2:struts2获取前台数据(action中获取) //4修改用户密码. public String updateUserPassword() throws Exception{ ...
- 一种高兼容性的JavaBean序列化方案
在对JavaBean做序列化时,我们可能在某些场景希望前后兼容性好一些.比如所有的javaBean都序列化后保存在数据库,用的时候需要反序列化创建.随着业务的发展,数据模型可能会进行变更,那么原来的数 ...
- JavaSE 基础习题整理 - 面向对象篇
大家好,今天空闲时间整理了一份JavaSE面向对象的常用习题,喜欢的朋友可以关注我.习题来自互联网,不喜勿喷 1.定义长方形类,含: 属性:宽.高(整型): 方法:求周长.面积: 构造方法3个:(1) ...
- Sql批量插入方法
using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...
- hdu2029
http://acm.hdu.edu.cn/showproblem.php?pid=2029 #include<stdio.h> #include<string.h> #inc ...
- 使用HBuilder新建项目
依次点击文件→新建→选择Web项目(按下Ctrl+N,W可以触发快速新建(MacOS请使用Command+N,然后左键点击Web项目)) 如上图,请在A处填写新建项目的名称,B处填写(或选择)项目保存 ...
- servlet范围:数据共享
数据共享: 请求转发:request.getDispatcher("相对路径").forward(request,response) 重定向:response.sendRedire ...
- 【Leetcode】115. Distinct Subsequences
Description: Given two string S and T, you need to count the number of T's subsequences appeared in ...
- unity多语言本地化
简介 嗯...一般来说做游戏啥的都不会只发一个国家,但是每个国家语言不同,就存在多语言本地化的问题,然后直接用过一个通过xml完成本地化的东东,然后策划反馈不会修改xml,扔给我一个excel让我自己 ...
- MySQL关于视图的创建
-- 视图就是一条select 语句 执行后返回结果集,是一种虚拟表,是一个逻辑表 -- 方便操作,减少复杂的SQL语句,增加可读性,更加安全一些 create view demo_view as s ...