Mayan游戏

小编 2026-06-30 阅读:1165 评论:0
题目略 我们把空白看成0,那么共有4种移动方法 x优先于y,可以通过循环实现 1优先于-1,看下面 我们必须保证第一个搜到的就是最优解,搜到解就return 空白,跳过 不在右边界,右移...

题目略


我们把空白看成0,那么共有4种移动方法
x优先于y,可以通过循环实现
1优先于-1,看下面
我们必须保证第一个搜到的就是最优解,搜到解就return

  • 空白,跳过
  • 不在右边界,右移
  • 右边界且左边为0(若左边不是空,从左边格子右移更优),左移
  • 不在左右边界且左边为0(因为这种前面没办法右移完成),左移

接下来看代码
我这里的dfs(nn)是指进行第nn次移动
所以在memcpy之前一定要记得nn-1!!!
因为这个卡了好久QAQ

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
using namespace std;
int n;
int x=0;
int m[10][10][15];
int book[6][8];
int a[10],b[10],c[10];
void fall(int nn,int x)
{
	int k=-1;
	int i=0;
	while(i<7)
	{
		if(k!=-1 && m[nn][x][i])
		{
			int j=i;
			m[nn][x][k]=m[nn][x][i];
			while(m[nn][x][j] && j<7)
			{
				k++;
				j++;
				m[nn][x][k]=m[nn][x][j];					
			}			
			for(int u=k+1;u<(j<=7?j:7);u++)
			{
				m[nn][x][u]=0;//没有被赋值的置为0 
			} 
			//m[nn][x][j]等于0 最后一个把值赋给了其他人的是m[nn][x][j-1]
			i=k+1;//此时m[nn][x][k]=0 
		}
		else if(k==-1 && !m[nn][x][i])//只有第一次要用到这个 不然会出错 
		{
			k=i;
			i++;
		}
		else i++;
	}
}
int check(int nn)
{
	int changed=0;
	memset(book,0,sizeof(book));
	for(int i=0;i<5;++i)
	{
		for(int j=0;j<7;++j)
		{
			if(m[nn][i][j]==m[nn][i+1][j] && m[nn][i][j]==m[nn][i+2][j] && m[nn][i][j]!=0)
			//千万不能写连等 QAQ
			{
				changed=1;
				book[i][j]=1;
				book[i+1][j]=1;
				book[i+2][j]=1;
			}
			if(m[nn][i][j]==m[nn][i][j+1] && m[nn][i][j]==m[nn][i][j+2] && m[nn][i][j]!=0)
			{
				changed=1;
				book[i][j]=1;
				book[i][j+1]=1;
				book[i][j+2]=1;
			}
		}
	}
	if(changed)
	{
		for(int i=0;i<5;++i)
		{
			for(int j=0;j<7;++j)
			{
				if(book[i][j]) m[nn][i][j]=0;
			}
		}
	}
	return changed;
}
int dfs(int nn)
{
	if(nn>n)
	{
		for(int i=0;i<5;++i)
		{
			if(m[n][i][0]) return 0;
		}
		return 1;
	}
	for(int i=0;i<5;++i)
	{
		for(int j=0;j<7;++j)
		{
			if(!m[nn-1][i][j]) continue;//m[nn]也没有定义... 
			if(i<4) c[nn]=1;//不在右边界 优先右移 
			else if(i==4 && !m[nn-1][i-1][j]) c[nn]=-1;//在右边界且左边是0 
			//nn-1//nn-1//nn-1// 
			else continue;
			a[nn]=i;
			b[nn]=j;
			memcpy(m[nn],m[nn-1],sizeof(m[nn-1]));
			swap(m[nn][i][j],m[nn][i+c[nn]][j]);
			do{
				for(int p=0;p<5;++p)
				{
					fall(nn,p);
				}
			}while(check(nn));
			if(dfs(nn+1))
			{
				return 1;
			}
			if(i>0 && i<4 && !m[nn][i-1][j])//不在左右边界且左边是0 
			{
				a[nn]=i;
				b[nn]=j;
				c[nn]=-1;
				memcpy(m[nn],m[nn-1],sizeof(m[nn-1]));
				swap(m[nn][i][j],m[nn][i-1][j]);
				do{
					for(int p=0;p<5;++p)
					{
						fall(nn,p);
					}
				}while(check(nn));
				if(dfs(nn+1)) return 1;
			}
		}
	}
	return 0;
}
int main(){
	memset(m,0,sizeof(m));
	scanf(\"%d\",&n);
	for(int i=0;i<5;++i)
	{
		int j=0;
		do{
			scanf(\"%d\",&m[0][i][j]);
			j++;
		}while(m[0][i][j-1]);//m[0][i][j]还没有定义 
	}
	x=dfs(1);
	if(x)
	{
		for(int i=1;i<=n;++i)
		{
			printf(\"%d %d %d\\n\",a[i],b[i],c[i]);
		}
	}
	else printf(\"-1\\n\");
	return 0;
}
版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

热门文章
  • 机房智能化温湿度解决方式之POE供电以太网温湿度传感器

    机房智能化温湿度解决方式之POE供电以太网温湿度传感器
    机房智能化温湿度解决方式之POE供电以太网温湿度传感器 北京盈创力和电子科技有限公司 智能型TCP网口温湿度记录仪 北京IP网络温湿度记录仪厂家,北京盈创力和 北京智能型TCP网口温湿度记录仪IP网络温湿度记录仪是一种新型的基于TCP/IP协议双绞线以太网标准温湿度采集模块,利用它可以实现现场温度值、相对湿度值的采集,同时利用其自身的RJ45通信接口可以方便地和机房监控主机或交换机集线器进行联网。 工作于-40℃~85℃工业级带...
  • Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering

    Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering
    Problem Statement 我们考虑一个具有马尔可夫性质、非线性、非高斯的状态空间模型(State Space Model):对于一个时间序列上的观测结果{yt,t∈N}\\{ y_t , t \\in N \\}{yt​,t∈N},我们认为每个观测结果yty_tyt​的生成依赖于一个无法直接观察的隐变量xt∈{xt,t∈N}x_t \\in \\{x_t , t \\in N \\}xt​∈{xt​,t∈N},即:p(...
  • HTTP状态保持的原理

    HTTP状态保持的原理
    a)在用户登录之后,浏览器返回响应的时候会在响应中添加上cookieb)浏览器接收到cookie之后会自动保存c)当用户再次请求同一服务器中的其他网页的时候,浏览器会自动带上之前保存的cookied)服务接收到请求之后可以请 request 对象中取到cookie 判断当前用户是否登录  Http是无状态的,就是连接时数据互通,关闭后...
  • Hive 系统函数及示例

    Hive 系统函数及示例
    查看所有系统函数 show functions; 函数分类 内置函数【系统函数】 数学函数: floor、round、ceil、cos、log2等 字符串函数: length、reverse、trim、lower、get_json_object、repeat等 收集函数: size 转换函数: cast 日期函数: year、month、datediff、date、date_add等 条件函数: coalesce、case…w...
  • CSRF的原理和防范措施

    CSRF的原理和防范措施
    a)攻击原理:i.用户C访问正常网站A时进行登录,浏览器保存A的cookieii.用户C再访问攻击网站B,网站B上有某个隐藏的链接或者图片标签会自动请求网站A的URL地址,例如表单提交,传指定的参数iii.而攻击网站B在访问网站A的时候,浏览器会自动带上网站A的cookieiv.所以网站A在接收到请求之后可判断当前用户是登录状态,所以...
标签列表