[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\)列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必 ...
随机推荐
- [bzoj1218][HNOI2003]激光炸弹_暴力
激光炸弹 bzoj-1218 HNOI-2003 题目大意:在笛卡尔坐标系上有n个点,问一个平行于坐标轴的r*r的正方形可以最多覆盖多少个目标. 注释:$1\le n \le 10000$,$1\le ...
- 开源工作流BPM软件JFlow安装配置视频教程
上周上传了一次,被抽了.刚開始不知道CSDN没有视频许可.造成一些爱好者无法下载,对此感到羞愧. 在下载后,依照文档内的连接,直接取出来就能够了,包括文档说明.视频教程两部分. http://down ...
- Linux - 常用网络命令详解netstat,scp
ifconfig 查看生效的ip信息. [root@local ~]# ifconfig eno16777736: flags=4163<UP,BROADCAST,RUNNING,MULTICA ...
- Wannafly挑战赛25 A 因子 数学
题面 题意:令 X = n!,给定一大于1的正整数p,求一个k使得 p ^k | X 并且 p ^(k + 1) 不是X的因子,n,,p(1e18>=n>=1e4>=p>=2) ...
- AWS S3 对象存储服务
虽然亚马逊云非常牛逼,虽然亚马逊云财大气粗,虽然亚马逊用的人也非常多,可是这个文档我简直无法接受,特别是客服,令人发指的回复速度,瞬间让人无语,可是毕竟牛逼.忍了,躺一次坑而已 1.图片上传 1.1 ...
- python字符串中的单双引
python中字符串可以(且仅可以)使用成对的单引号.双引号.三个双引号(文档字符串)包围: 'this is a book' "this is a book" "&qu ...
- poj 1161 Floyd+枚举
题意是: 给出n个点,围成m个区域.从区域到另一个区域间需穿过至少一条边(若两区域相邻)——边连接着两点. 给出这么一幅图,并给出一些点,问从这些点到同一个区域的穿过边数最小值. 解题思路如下: 将区 ...
- 试图ddms 如果丢失adv链接解决办法!
点击如下图菜单 重启链接adv即可显示.
- css中max-width和min-width的应用
max-width:从字面意思可以看出,是规定元素本身最大宽度,元素本身宽度应小于等于最大宽度值. min-width:从字面意思可以看出,是规定元素本身最小宽度,元素本身宽度应大于等于最小宽度值. ...
- jQuery中事件模块介绍
事件模块 1.提供其他DOM方法 包括:next 和 nextAll方法 1.1 next方法实现 目标:扩展框架方法,获取当前元素的下一个元素 问题:如何获取下一个元素? 1.1.1 提供 next ...