[noip2011 luogu1312] Mayan游戏(模拟)
原题:传送门
大模拟…
两个剪枝:
1.如果左边不为空就不往左边走(因为一定不如左边的移到右边优)
2.如果相邻两颜色相同不需移动
当然也有别的小剪枝(我没写)比如如果当前某一颜色剩余块数满足1<=x<=2就显然不可能满足等等
code;
//By Menteur_Hxy
#include <cstdio>
#include <cstring>
#include <iostream>
#define F(i,a,b) for(register int i=(a);i<(b);i++)
using namespace std;
int n;
int mp[20][5][7],ansx[20],ansy[20],ansv[20];
bool vis[5][7];
int rd() {
int x=0,fla=1; char c=' ';
while(c<'0' || c>'9') {c=getchar();if(c=='-') fla=-fla;}
while(c>='0' && c<='9') x=x*10+c-'0',c=getchar();
return x*fla;
}
void fall(int dep) {
F(i,0,5) { int cnt=0;
F(j,0,7) if(mp[dep][i][j]) mp[dep][i][cnt++]=mp[dep][i][j];
while(cnt<7) mp[dep][i][cnt++]=0;
}
}
void fre(int dep) {
bool flag=true;
while(flag) {
flag=false; fall(dep);
F(i,0,5) F(j,0,7) if(mp[dep][i][j]) {
if(i>1) if(mp[dep][i][j]==mp[dep][i-1][j] && mp[dep][i][j]==mp[dep][i-2][j])
flag=vis[i][j]=vis[i-1][j]=vis[i-2][j]=1;
if(j>1) if(mp[dep][i][j]==mp[dep][i][j-1] && mp[dep][i][j]==mp[dep][i][j-2])
flag=vis[i][j]=vis[i][j-1]=vis[i][j-2]=1;
}
F(i,0,5) F(j,0,7) if(vis[i][j]) mp[dep][i][j]=vis[i][j]=0;
}
}
bool dfs(int dep) {
F(i,0,5) F(j,0,7) mp[dep][i][j]=mp[dep-1][i][j];
fre(dep);
if(dep==n+1) {
F(i,0,5) if(mp[dep][i][0]) return false;
return true;
}
F(i,0,5) F(j,0,7) if(mp[dep][i][j]) {
if(i<4 && mp[dep][i][j]!=mp[dep][i+1][j]) {
ansx[dep]=i,ansy[dep]=j,ansv[dep]=1;
swap(mp[dep][i][j],mp[dep][i+1][j]);
if(dfs(dep+1)) return true;
swap(mp[dep][i][j],mp[dep][i+1][j]);
}
if(i && !mp[dep][i-1][j]) {
ansx[dep]=i,ansy[dep]=j,ansv[dep]=-1;
swap(mp[dep][i][j],mp[dep][i-1][j]);
if(dfs(dep+1)) return true;
swap(mp[dep][i][j],mp[dep][i-1][j]);
}
}
return false;
}
int main() {
n=rd();
F(i,0,5) F(j,0,9) {
int x=rd();
if(!x) break;
mp[0][i][j]=x;
}
if(dfs(1)) F(i,1,n+1) printf("%d %d %d\n",ansx[i],ansy[i],ansv[i]);
else printf("-1");
return 0;
}
[noip2011 luogu1312] Mayan游戏(模拟)的更多相关文章
- luogu1312 Mayan游戏 剪枝
题目大意 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个77 行\times 5×5列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上.游 ...
- 【noip2011】Mayan游戏
题解: 刷了一天的noip啊 做了10题! 突然找回了做马拉松的感觉- - 我中午竟然放弃治疗去看视频 做到晚上累得都快挂了 用电脑放一些rock 把音乐当咖啡硬撑下来 但是还是没能刷3届 唉 显然速 ...
- 「NOIP2011」Mayan游戏
传送门 Luogu 解题思路 爆搜,并考虑几个剪枝. 不交换颜色相同的方块(有争议,但是可以过联赛数据 \(Q \omega Q\)) 左边为空才往左换 右边不为空才往右换 因为对于两个相邻方块,右边 ...
- 洛谷P1312 [NOIP2011提高组Day1T3]Mayan游戏
Mayan游戏 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个 7 行5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上.游 ...
- NOIP2011 Mayan游戏
3 Mayan游戏 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个 7 行5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上 ...
- luoguP1312 Mayan游戏 题解(NOIP2011)
luoguP1312 Mayan游戏 题目 #include<bits/stdc++.h> #define ll long long #define rg register #define ...
- 洛谷P1312 Mayan游戏
P1312 Mayan游戏 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个 7 行5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他 ...
- Luogu 1312 【NOIP2011】玛雅游戏 (搜索)
Luogu 1312 [NOIP2011]玛雅游戏 (搜索) Description Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个7行5列的棋盘,上面堆放着一些方块,方块不能悬空 ...
- Luogu P1312 Mayan游戏(搜索)
P1312 Mayan游戏 题意 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个\(7\)行\(\times 5\)列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必 ...
随机推荐
- 配置db账号和密码时一定注意空格问题、空行问题否则连接报错
#postgresql dbpg.datasource.type=com.alibaba.druid.pool.DruidDataSourcepg.datasource.driverClassName ...
- HDUOJ--4888--Redraw Beautiful Drawings【isap】网络流+判环
链接:http://acm.hdu.edu.cn/showproblem.php? pid=4888 题意:一个矩阵.限定每行行和.列和,每一个格子数字不超过k,问矩阵是否存在,如存在推断有单解还是多 ...
- Cocos2d-x 3.0final 终结者系列教程02-开发环境的搭建
本文主要以Mac平台和XCode5为基本系统环境和C++编程工具来介绍Cocos2d-x3.0final版的安装. 一.系统准备(预计要花掉半个月工资) MacBook Pro一台(本人的比較老.11 ...
- php建立简单的用户留言系统
php建立简单的用户留言系统 样例 addMsg.php--添加留言页面 doAction.php--响应添加留言页面 . viewMsg.php--显示留言页面 目录结构 addMsg.php--添 ...
- [ligerUI] grid封装调用方法
/** * 获取页面参数 */ function getPageSize(){ var xScroll, yScroll; if (window.innerHeight && wind ...
- mod_wsgi 初体验
1, 安装 ./configure --with-apxs=/usr/local/apache2/bin/apxs --with-python=/usr/bin/python3 make && ...
- 学习英语的小习惯(IT版) 不断补充中~~~~~~
对于一些英文单词的读音,包含各种类似于Linux,Maven,Python……这些单词,尽量第一时间去找到他们的标准或者地道的发音,不要随便读,以免后面发音很难纠正. 有道词典的屏幕取词和划词很好用, ...
- B - Expression
Problem description Petya studies in a school and he adores Maths. His class has been studying arith ...
- javascript中caller和callee call和apply
Arguments : 该对象代表正在执行的函数和调用它的函数的参数. [function.]arguments[n] 参数function :选项.当前正在执行的 Function 对象的名字. n ...
- 如何修改 WordPress 数据库前缀
我们知道 WordPress 的数据库表,可以设置前缀,默认是 wp_,很多同学也就默认用了 wp_,如果某种原因(比如提高安全性)要修改的 WordPress 数据的前缀,我们应该怎么做? 开始之前 ...