[BZOJ1054][HAOI2008]移动玩具 bfs+hash
1054: [HAOI2008]移动玩具
Time Limit: 10 Sec Memory Limit: 162 MB
Submit: 2432 Solved: 1355
[Submit][Status][Discuss]
Description
Input
Output
一个整数,所需要的最少移动次数。
Sample Input
0000
1110
0010
1010
0101
1010
0101
Sample Output
- #include<iostream>
- #include<cstring>
- #include<cstdio>
- #include<cstdlib>
- #include<cmath>
- #include<algorithm>
- using namespace std;
- char a[][];
- int t=;
- int k=;
- int now=;
- int dis[];
- int q[];
- void bfs() {
- memset(dis,,sizeof(dis));
- int head=,tail=;
- q[head]=now;
- dis[now]=;
- while(head!=tail) {
- int n=q[head++];
- for(int i=;i<=;i++) {
- for(int j=;j<=;j++){
- int to=<<((i-)*+j-);
- if(!(n&to)) continue;
- if(i>) {
- int tt=to>>;
- if(!(n&tt)) {
- int next=n-to+tt;
- if(dis[next]>dis[n]+) {dis[next]=dis[n]+;q[tail++]=next;}
- if(next==t){printf("%d",dis[next]);return;}
- }
- }
- if(j>) {
- int tt=to>>;
- if(!(n&tt)) {
- int next=n-to+tt;
- if(dis[next]>dis[n]+) {dis[next]=dis[n]+;q[tail++]=next;}
- if(next==t){printf("%d",dis[next]);return;}
- }
- }
- if(j<) {
- int tt=to<<;
- if(!(n&tt)) {
- int next=n-to+tt;
- if(dis[next]>dis[n]+) {dis[next]=dis[n]+;q[tail++]=next;}
- if(next==t){printf("%d",dis[next]);return;}
- }
- }
- if(i<) {
- int tt=to<<;
- if(!(n&tt)) {
- int next=n-to+tt;
- if(dis[next]>dis[n]+) {dis[next]=dis[n]+;q[tail++]=next;}
- if(next==t){printf("%d",dis[next]);return;}
- }
- }
- }
- }
- }
- }
- int main(){
- for(int i=;i<=;i++) {
- scanf("%s",a[i]);
- for(int j=;j<=;j++){
- now+=(a[i][j-]-'')*k;
- k<<=;
- }
- }
- k=;
- for(int i=;i<=;i++) {
- char x[];
- scanf("%s",x);
- for(int j=;j<=;j++){
- t+=(x[j-]-'')*k;
- k<<=;
- }
- }
- bfs();
- }
[BZOJ1054][HAOI2008]移动玩具 bfs+hash的更多相关文章
- 【BZOJ1054】[HAOI2008]移动玩具 BFS
[BZOJ1054][HAOI2008]移动玩具 Description 在一个4*4的方框内摆放了若干个相同的玩具,某人想将这些玩具重新摆放成为他心中理想的状态,规定移动 时只能将玩具向上下左右四个 ...
- bzoj1054: [HAOI2008]移动玩具
hash+bfs:要注意特殊情况.(似乎连sort.lower_bound都不用数据小直接判重了... #include<cstdio> #include<cstring> # ...
- bzoj 1054: [HAOI2008]移动玩具 bfs
1054: [HAOI2008]移动玩具 Time Limit: 10 Sec Memory Limit: 162 MB[Submit][Status][Discuss] Description 在 ...
- 【BFS】bzoj1054 [HAOI2008]移动玩具
暴搜吧,可以哈希一下,但是懒得写哈希了,所以慢得要死. Code: #include<cstdio> #include<queue> #include<set> # ...
- bzoj1054: [HAOI2008]移动玩具 状压+爆搜即可
题意:在一个4*4的方框内摆放了若干个相同的玩具,某人想将这些玩具重新摆放成为他心中理想的状态,规定移动时只能将玩具向上下左右四个方向移动,并且移动的位置不能有玩具,请你用最少的移动次数将初的玩具状态 ...
- 【BZOJ】1054: [HAOI2008]移动玩具(bfs+hash)
http://www.lydsy.com/JudgeOnline/problem.php?id=1054 一开始我还以为要双向广搜....但是很水的数据,不需要了. 直接bfs+hash判重即可. # ...
- P4289 [HAOI2008]移动玩具(bfs)
P4289 [HAOI2008]移动玩具 双向bfs+状态压缩+记忆化搜索 双向bfs用于对bfs的优化,每次找到可扩展节点少的一边进行一次bfs,找到的第一个互相接触的点即为最短路径 矩阵范围仅4* ...
- 【BZOJ1054】[HAOI2008]移动玩具
[BZOJ1054][HAOI2008]移动玩具 题面 bzoj 洛谷 题解 太\(sb\)了,不想写了,直接点开洛谷题面单击右边蓝色按钮题解即可
- BZOJ 1054 [HAOI2008]移动玩具
1054: [HAOI2008]移动玩具 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1388 Solved: 764[Submit][Statu ...
随机推荐
- 无限小数转分数POJ1930分析
将无限小数化为分数,有一套简单的公式.使其轻松表示出来. 循环节 例如:0.121212…… 循循环节为12. 公式 这个公式必须将循环节的开头放在十分位.若不是可将原数乘10^x(x为正整数) ...
- java和c/c++
写c/c++的人,羡慕java可以自己管理内存 写java的人,羡慕c/c++没有gc问题
- 【Lowest Common Ancestor of a Binary Search Tree】cpp
题目: Given a binary search tree (BST), find the lowest common ancestor (LCA) of two given nodes in th ...
- 服务过美国总统竞选的非传统投票UI [解析及DEMO]
上篇文章和大家介绍了需求情况和难点分析,大家可以看这个链接了解详细 服务过美国总统竞选的非传统投票UI =================正文开始=================== ...
- Windows下安装PHP及开发环境配置
一.Apache 因为Apache官网只提供源代码,如果要使用必须得自己编译,这里我选择第三方安装包Apache Lounge. 1. 进入Apachelounge官方下载地址:http://www. ...
- Java基础-3类和对象声明与创建
一).在1和2中有粗略介绍过类和对象的概念,在这里简单回顾一下: 对象与类:一个实际或者虚拟的物体,这个物体既是我们的对象,这个物体呢又是属于一个分类,如动物类,人类 二).创建对象: 在创建对象的时 ...
- win10 64位 C# 连接oracle 32位, 遇到的问题及解决
首次 本机电脑是win10系统 64位的:安装的oracle数据库也是64位的: 服务器端的oracle 是32位的: 第一次安装的pl/sql 也是64位的, 配置完 F:\app\ln_qi\p ...
- 团队项目-第七次scrum 会议
时间:11.3 时长:30分钟 地点:F楼1039教室 工作情况 团队成员 已完成任务 待完成任务 解小锐 学习cocos creator样例 修复员工招聘时bug 陈鑫 完成fire()与UI的对接 ...
- fisheye在centos上的安装
目录 描述 部署过程 安装及配置 破解 添加存贮库 在jira上配置 描述 Fisheye 一个源代码库深度查看软件,它可以挖掘源代码库中的有用信息,呈现在Web浏览器界面上. Crucible是一个 ...
- PHP面向对象 封装与继承
知识点: PHP封装三个关键词: 一.public 公有的,被public修饰的属性和方法,对象可以任意访问和调用 二.private 私有的,被private修饰的属性和方法,只能在类内部的方法可以 ...