【HAOI 2008】 移动玩具
【题目链接】
https://www.lydsy.com/JudgeOnline/problem.php?id=1054
【算法】
广度优先搜索
【代码】
#include<bits/stdc++.h>
using namespace std;
const int dx[] = {,,-,};
const int dy[] = {-,,,};
const int MAXS = << ; struct info
{
int mp[][];
int step;
} ; int i,j,k,goal,tx,ty,l,r,state;
int mp[][],g[][];
info q[MAXS];
info cur,tmp;
bool visited[MAXS]; inline bool valid(int x,int y)
{
return x > && x <= && y > && y <= ;
}
inline int get(int a[][])
{
int i,j,ret = ;
int b = ;
for (i = ; i <= ; i++)
{
for (j = ; j <= ; j++)
{
ret += a[i][j] * b;
b <<= ;
}
}
return ret;
} int main()
{ for (i = ; i <= ; i++)
{
for (j = ; j <= ; j++)
{
mp[i][j] = getchar() - '';
}
getchar();
}
getchar();
for (i = ; i <= ; i++)
{
for (j = ; j <= ; j++)
{
g[i][j] = getchar() - '';
}
getchar();
}
goal = get(g);
visited[get(mp)] = true;
if (visited[goal])
{
printf("0\n");
return ;
}
l = r = ;
memcpy(q[].mp,mp,sizeof(q[].mp));
q[].step = ;
while (l <= r)
{
cur = q[l];
l++;
for (i = ; i <= ; i++)
{
for (j = ; j <= ; j++)
{
if (cur.mp[i][j] == )
{
for (k = ; k < ; k++)
{
tx = i + dx[k];
ty = j + dy[k];
if (valid(tx,ty) && cur.mp[tx][ty] == )
{
swap(cur.mp[i][j],cur.mp[tx][ty]);
state = get(cur.mp);
if (!visited[state])
{
visited[state] = true;
if (state == goal)
{
printf("%d\n",cur.step+);
return ;
}
r++;
memcpy(q[r].mp,cur.mp,sizeof(q[r].mp));
q[r].step = cur.step + ;
}
swap(cur.mp[i][j],cur.mp[tx][ty]);
}
}
}
}
}
} return ; }
【HAOI 2008】 移动玩具的更多相关文章
- [BZOJ 1054][HAOI 2008]移动玩具 状态压缩
考试的时候一看是河南省选题,觉得会很难,有点不敢想正解.感觉是个状压.但是一看是十年前的题,那怂什么! 直接把十六个数的状态压进去,因为个数是不变的,所以状态枚举的时候只要找数目一样的转移即可.而且只 ...
- [ HAOI 2008 ] 玩具取名
\(\\\) \(Description\) 在一个只有\(W,I,N,G\)的字符集中,给出四个字符的若干映射,每个映射为一个字符映射到两个字符,现给你一个假定由一个字符经过多次映射产生的字符串,问 ...
- BZOJ 1010 (HNOI 2008) 玩具装箱
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MB Submit: 12665 Solved: 5540 [Submit][S ...
- [HAOI 2008]木棍分割
Description 题库链接 有 \(n\) 根木棍,第 \(i\) 根木棍的长度为 \(L_i\) , \(n\) 根木棍依次连结了一起,总共有 \(n-1\) 个连接处.现在允许你最多砍断 \ ...
- [HAOI 2008]硬币购物
Description 硬币购物一共有4种硬币.面值分别为c1,c2,c3,c4.某人去商店买东西,去了tot次.每次带di枚ci硬币,买si的价值的东西.请问每次有多少种付款方法. Input 第一 ...
- [HAOI 2008]糖果传递
Description 有n个小朋友坐成一圈,每人有ai个糖果.每人只能给左右两人传递糖果.每人每次传递一个糖果代价为1. Input 第一行一个正整数nn<=1'000'000,表示小朋友的个 ...
- 【HAOI 2008】 硬币购物
[题目链接] 点击打开链接 [算法] 此题是一道好题! 首先,我们发现 : 付款方法数 = 不受限制的方法数 - 受限制的方法数 那么,我们怎么求呢? 我们用dp求出不受限制的方法数(f[i]表示买i ...
- [ HAOI 2008 ] 圆上的整点
\(\\\) Description 给出一个整数 \(r\) ,求圆 \(x^2+y^2=r^2\) 上的整点数. \(r\le 2\times 10^9\) \(\\\) Solution 神题. ...
- 【HAOI 2008】 糖果传递
[题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1045 [算法] 环形均分纸牌问题 [代码] #include<bits/std ...
随机推荐
- 《CSS Mastery》 读书笔记 (1)
--本笔记中英混合,专业名词尽量不翻译,免得误解,如果不习惯,就不用往下看了,走好不送. 第一章 基础 人类的好奇心总是促使我们捣鼓,捣鼓是最好做有效的学习CSS的方法 In this chapter ...
- vue中的config配置
在webpack.base.conf文件中配置别名以及扩展名 resolve: { extensions: ['.js', '.vue', '.json', '.styl'], alias: { 'v ...
- vue-router简单用法
路由,其实就是指向的意思,当我点击页面上的home按钮时,页面中就要显示home的内容,如果点击页面上的about 按钮,页面中就要显示about 的内容.Home按钮 => home 内容, ...
- Android 概览屏幕
文章照搬过来的:原文地址https://developer.android.google.cn/guide/components/recents.html 概览屏幕(也称为最新动态屏幕.最近任务列表或 ...
- std::string格式化输入输出
在C语言中: C函数有sprintf函数, 比较方便, 但是需要知道所需要的内存空间是多少. 在C++的框架MFC中: 在MFC中CString 有Format函数来格式化字符串. 很方便. 难过的是 ...
- python迭代器,生成器,推导式
可迭代对象 字面意思分析:可以重复的迭代的实实在在的东西. list,dict(keys(),values(),items()),tuple,str,set,range, 文件句柄(待定) 专业角度: ...
- 微信小程序swiper bindChange重复执行
swiper是微信小程序的一个滑动组件,非常重要.如果只是做简单的轮播图而不进行复杂的逻辑,直接可以使用,甚至不需要知道组件的方法.今天在做一个如下的页面时,快速滑动swiper出现了问题: 控制台打 ...
- elasticsearch重建索引
1.重建索引 一个field的设置是不能被修改的,如果要修改一个Field,那么应该重新按照新的mapping,建立一个index,然后将数据批量查询出来,重新用bulk api写入index中 批量 ...
- PAT_A1120#Friend Numbers
Source: PAT A1120 Friend Numbers (20 分) Description: Two integers are called "friend numbers&qu ...
- 启动模拟器的qq
#coding = utf-8from appium import webdriver '''1.手机类型2.版本3.手机的唯一标识 deviceName4.app 包名appPackage5.app ...