[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\)列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必 ...
随机推荐
- spring-logback
<?xml version="1.0" encoding="UTF-8"?><!-- 说明: 1.日志级别及文件 日志记录采用分级记录,级别与 ...
- HDUOJ--4888--Redraw Beautiful Drawings【isap】网络流+判环
链接:http://acm.hdu.edu.cn/showproblem.php? pid=4888 题意:一个矩阵.限定每行行和.列和,每一个格子数字不超过k,问矩阵是否存在,如存在推断有单解还是多 ...
- org.openqa.selenium.NoSuchElementException:
http://www.blogjava.net/qileilove/archive/2014/12/11/421309.html selenium webdriver定位不到元素的五种原因及解决办法 ...
- C语言读取文件大量数据到数组
针对.txt文档的大量有规律数据,譬如100行8列的数据将其读取到二维数组(矩阵)中,留作之后的数据处理. 改程序通过宏定义的方法来确定将要读取程序的行数和列数,将数据读取到二维数组data[100] ...
- CharsRefIntHashMap并不比HashMap<String, Integer>快
我模仿lucene的BytesRef写了一个CharsRefIntHashMap,实測效果并不如HashMap<String, Integer>.代码例如以下: package com.d ...
- OLR文件丢失的恢复
11.2.0.1的RAC中,rac1和rac2 一.OLR有备份的情况 1.手动将rac1中的olr重命名,模拟丢失 mv rac1.olr rac1.olr.test 2.重新启动crs ./crs ...
- makepy
文件连接: https://files.cnblogs.com/files/mophy/%E7%99%BB%E5%BD%95%E6%B5%81%E7%A8%8B%E5%88%86%E6%9E%90.7 ...
- Node.js:目录
ylbtech-Node.js:目录 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 1. http://www.runoob.com/nodejs/nodejs ...
- 向量叉乘 Cross product
参考:Wiki Cross product
- 实现第三方登录(QQ、微信、微博)
第三方登录,就是使用大家比较熟悉的比如QQ.微信.微博等第三方软件登录自己的网站,这可以免去注册账号.快速留住用户的目的,免去了相对复杂的注册流程.下边就给大家讲一下怎么使用PHP开发QQ登录的功能. ...