原题:传送门

大模拟…

两个剪枝:

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游戏(模拟)的更多相关文章

  1. luogu1312 Mayan游戏 剪枝

    题目大意 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个77 行\times 5×5列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上.游 ...

  2. 【noip2011】Mayan游戏

    题解: 刷了一天的noip啊 做了10题! 突然找回了做马拉松的感觉- - 我中午竟然放弃治疗去看视频 做到晚上累得都快挂了 用电脑放一些rock 把音乐当咖啡硬撑下来 但是还是没能刷3届 唉 显然速 ...

  3. 「NOIP2011」Mayan游戏

    传送门 Luogu 解题思路 爆搜,并考虑几个剪枝. 不交换颜色相同的方块(有争议,但是可以过联赛数据 \(Q \omega Q\)) 左边为空才往左换 右边不为空才往右换 因为对于两个相邻方块,右边 ...

  4. 洛谷P1312 [NOIP2011提高组Day1T3]Mayan游戏

    Mayan游戏 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个 7 行5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上.游 ...

  5. NOIP2011 Mayan游戏

    3 Mayan游戏 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个 7 行5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他方块之上 ...

  6. luoguP1312 Mayan游戏 题解(NOIP2011)

    luoguP1312 Mayan游戏 题目 #include<bits/stdc++.h> #define ll long long #define rg register #define ...

  7. 洛谷P1312 Mayan游戏

    P1312 Mayan游戏 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个 7 行5 列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必须放在最下面一行,或者放在其他 ...

  8. Luogu 1312 【NOIP2011】玛雅游戏 (搜索)

    Luogu 1312 [NOIP2011]玛雅游戏 (搜索) Description Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个7行5列的棋盘,上面堆放着一些方块,方块不能悬空 ...

  9. Luogu P1312 Mayan游戏(搜索)

    P1312 Mayan游戏 题意 题目描述 Mayan puzzle是最近流行起来的一个游戏.游戏界面是一个\(7\)行\(\times 5\)列的棋盘,上面堆放着一些方块,方块不能悬空堆放,即方块必 ...

随机推荐

  1. 【ACM】hdu_1170_Balloon Comes!_201307261946

    Balloon Comes!Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  2. spring boot使用外部tomcat部署

    1:pom里面的packaging修改为war(<packaging>war</packaging>) 2:在pom依赖spring-boot-starter-web排除内置的 ...

  3. 黑马程序猿——JAVA基础——集合

    ----------android培训.java培训.java学习型技术博客.期待与您交流.------------  一.关于java中的集合类        首先看一下,大致的框架流程图     ...

  4. 问题2-:Syntax error on tokens, delete these tokens

    出现原因:拷贝下来的代码缺少{左大括号 然后运行时run as 没有选到java application 是因为没有main方法 加个public static void main(String() ...

  5. 2015年趋势科技笔试A卷

    题目原题来源:url=BHz9dr7Dbql5Ai0fTaUsi8QH-ieA9UAtw8kpf-Us_cGUnsz7ZIU1SfHIp33Cphcp0n6uPikWL6r8n0a0zQ0wNOMLG ...

  6. ubuntu下创建第一个rails应用程序

    一.创建一个新的应用程序 在控制台输入 > rails new  demo create create README.rdoc create Rakefile create config.ru ...

  7. iOS8 tableView的Cell高度自适应开发

    1.在- (void)viewDidLoad中设置: //估计高度为81 self.tableView.estimatedRowHeight = 81.0f; //自适应高度 self.tableVi ...

  8. luogu1403 约数研究

    题目大意:给出n,求1~n所有数的约数个数的和. 将“1~n所有数的约数”的模板中的factor[i*j].push_back(i)改为FactorCnt[i*j]++,最后再求一次和即可. #inc ...

  9. 【NOIP 2004】 虫食算

    [题目链接] https://www.luogu.org/problemnew/show/P1092 [算法] 搜索 + 剪枝 直接搜索显然会超时,考虑剪枝 1 : 优化搜索顺序 2 : 假设我们已经 ...

  10. DBS-PowerDesginer:PowerDesigner最基础的使用方法入门学习

    ylbtech-DBS-PowerDesginer:PowerDesigner最基础的使用方法入门学习 1.返回顶部 1. 1:入门级使用PowerDesigner软件创建数据库(直接上图怎么创建,其 ...