ssl1692-魔板【HSAH,bfs】

前言

好的,首先说明一下,这里用的是字符串的方法。根据c++字符串的尿性,速度比较慢,当然也可以改成字符数组,只不过我比较懒(没错╭(╯^╰)╮)


正题

有个2*4的矩阵被称为魔板,有三种操作
“A”:交换上下两行;
“B”:将最右边的一列插入最左边;
“C”:魔板中央四格作顺时针旋转。
然后初始状态是
1 2 3 4
8 7 6 5
然后嘞,就是嘞
给出一个状态,要求改变到那个状态。


输入输出(建议无视)

Input

只有一行,包括8个整数,用空格分开(这些整数在范围 1——8 之间),表示目标状态。

Output

Line 1: 包括一个整数,表示最短操作序列的长度。
Line 2: 在字典序中最早出现的操作序列,用字符串表示,除最后一行外,每行输出60个字符。

Sample Input

2 6 8 4 5 7 3 1

Sample Output

7
BCABCCB


解题思路

这道题就是得把一块板线性化,然后找出变化规律。然后用哈希来判断重复优化广搜。
将线性化之后的版转换为数字,然后存进哈希表里判断重复。


代码

#include<cstdio>
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
const int ruler[3][8]={{8,7,6,5,4,3,2,1},{4,1,2,3,6,7,8,5},{1,7,2,4,5,3,6,8}};
//变化公式
string state[100003];//状态
string hash[100003],ss;//哈希表
int head,tail,z,x,father[100003],num[100003];
char dot[100003];
int hashm(string s)//哈希表
{int w=0;for (int i=0;i<8;i++){w=w*10+s[i]-48;}//转成数字w%=100003;//哈希函数int i=0;while (i<100003 && hash[(w+i)%100003]!="" && hash[(w+i)%100003]!=s)i++;//定位if (hash[(w+i)%100003]=="")//如果找到空位{hash[(w+i)%100003]=s;//记录return false;}else return true;//放回找到
}
void bfs()
{   hashm("12345678");//记录状态head=0;tail=1;state[1]="12345678";//状态记录do{head++;//出队for (int i=0;i<3;i++){tail++;//入队father[tail]=head;//记录上一个state[tail]="";//状态为空num[tail]=num[head]+1;//记录改变次数if (i==0) dot[tail]='A';if (i==1) dot[tail]='B';if (i==2) dot[tail]='C';//记录操作for (int j=0;j<8;j++){state[tail]+=state[head][ruler[i][j]-1];//变化状态}if (hashm(state[tail])) tail--;//拒绝入队else if (state[tail]==ss) return;//找到退出}}while(head<tail);
}
void print(int x)
{if (x==1) return;print(father[x]);//返回printf("%c",dot[x]);//输出
}
int main()
{for (int i=0;i<8;i++){scanf("%d",&x);ss+=x+48;//字符串}if (ss=="12345678") printf("0");//特殊判断else{bfs();//广搜printf("%d\n",num[tail]);//输出print(tail);//输出操作}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/324760.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

训练集样本不平衡问题对CNN的影响

转载自 训练集样本不平衡问题对CNN的影响 训练集样本不平衡问题对CNN的影响 本文首发于知乎专栏“ai insight”&#xff01; 卷积神经网络&#xff08;CNN&#xff09;可以说是目前处理图像最有力的工具了。 而在机器学习分类问题中&#xff0c;样本不平衡又是一个经常遇到…

银行转账案例

[1] 案例需求 用户访问登录页面&#xff0c;在页面中输入用户名和密码点击登录&#xff0c;登录成功后 进入到主页中。如果登录败&#xff0c;则在登录页面中提示用户用户名或密码错误。在主页面中&#xff0c;用户在填写银行转账信息&#xff0c;包括:转账账户&#xff0c;转账…

20级、19级 | 一天一瞬间!【日更】

点击上方蓝色关注我们&#xff01;欢迎来到今天的一天一瞬间专栏今天是2020年09月08日&#xff0c;天气状况&#xff1a;炎热。19级目前还是上午上课下午补课&#xff0c;补课私下里和我说&#xff0c;班内学生表现都不错&#xff0c;听罢&#xff0c;甚是开心&#xff0c;不管…

一张图看懂小程序全生态

6月9日小程序发布整半年&#xff0c;这半年里&#xff0c;小程序接连经历了&#xff1a;受追捧——遇冷——质疑——趋于理性的过程。我们对小程序这半年来的产业发展做了全面的梳理&#xff0c;从中可以发现&#xff0c;小程序已俨然形成了自己的生态体系&#xff0c;这一生态…

自然语言处理中的Attention Model:是什么以及为什么[一]

转载自 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[一] 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[一] 1、前言 要是关注深度学习在自然语言处理方面的研究进展&#xff0c;我相信你一定听说过Attention Model&#xff08;后文有时…

❤️ 爆肝一个月!JAVA零基础入门总结(下)❤️

程序、进程、线程 程序(program) 是为完成特定任务、用某种语言编写的一组指令的集合。即指一段静态的代码&#xff0c;静态对象。 进程(process) 是程序的一次执行过程&#xff0c;或是正在运行的一个程序。是一个动态的过程&#xff1a;有它自身的产生、存在和消亡的过程…

204787 ,194787 |0001 1131 0001 4226 7035 ![2480 ]

点击上方蓝色关注我们&#xff01;0006 6143 0037 7139 ,2598 4192 0007 7240 0681 1331 0226 ?6849 ?0784 4104 6943 4149 2418 2345 5116 ,7119 0354 0055 3089 1835 ,5261 1783 0250 2601 0110 0171 ,6290 0138 4972 1421 0055 7820 0087 8010 0138 4104 ?1927 1927 ,076…

DDD理论学习系列(9)-- 领域事件

1. 引言 A domain event is a full-fledged part of the domain model, a representation of something that happened in the domain. Ignore irrelevant domain activity while making explicit the events that the domain experts want to track or be notified of, or whi…

ssl1127-方程的解数【HASH,dfs】

前言 我只是凑数的。 正题 输入输出&#xff08;建议无视&#xff09; Input 第1行包含一个整数n。第2行包含一个整数M。第3行到第n2行&#xff0c;每行包含两个整数&#xff0c;分别表示ki和pi。两个整数之间用一个空格隔开。第3行的数据对应i1&#xff0c;第n2行的数据对应…

自然语言处理中的Attention Model:是什么以及为什么[二]

转载自 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[二] 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[二] 1、Attention Model 图一见下&#xff1a; 图1中展示的Encoder-Decoder模型是没有体现出“注意力模型”的&#xff0c;所以可以…

SpringAOP之代理设计模式

[1]设计模式: 概念: 设计模式其实就是代码的一种结构的设计思路。 好处: 增加代码健壮性 易修改性 可扩展性 设计模式的种类: 三大种类: 建造类设计模式 结构类设计模式 行为类设计模式 参考网址: http://baijiahao.baidu.com/s?id1639156298714178350&wfrspider&forp…

教师节快乐!

点击上方蓝色关注我们&#xff01;今天是个特殊的节日&#xff0c;教师节&#xff0c;从昨天开始就有学生给我发教师节祝福了……诺&#xff0c;发就发了吧&#xff0c;还害羞&#xff01;早上一醒来&#xff0c;就看到同学们在群里发祝福&#xff0c;心理美滋滋的。还有直接改…

ssl1063-统计数字【哈希表】

前言 先做赌徒的&#xff0c;结果发现这道题太TM简单了&#xff0c;然后就先做这道题了。 正题 给出n&#xff08;1<n<200000&#xff09;个数字&#xff0c;每个数字不超过1500000000。求每个数字出现的次数 输入输出&#xff08;建议无视&#xff09; Input 输入包含…

如何利用.NET Core搭建跨平台的控制台应用程序

尽管传统意义上来说&#xff0c;.NET是只面向Windows的、闭源的专有平台&#xff0c;然而&#xff0c;传统观念即将被颠覆。新的开源跨平台的.NET Core已经开启&#xff0c;意味着你可以在任意平台写C#或.NET&#xff0c;然后在Windows、Linus和macOS运行。 这个新的.NET平台正…

自然语言处理中CNN模型几种常见的Max Pooling操作

转载自 自然语言处理中CNN模型几种常见的Max Pooling操作 自然语言处理中CNN模型几种常见的Max Pooling操作 CNN是目前自然语言处理中和RNN并驾齐驱的两种最常见的深度学习模型。 图1展示了在NLP任务中使用CNN模型的典型网络结构。 一般而言&#xff0c;输入的字或者词用…

SpringTX

文章目录SpringTX的介绍SpringTX的使用代码示例声明式事务中属性解释SpringBoot中AOP事务配置SpringTX的介绍 问题&#xff1a; 在学习了Spring整合mybatis后&#xff0c;我们可以直接从Spring容器中获取mapper层的实例化对象完成数据库操作。而在业务层方法中很多时候因为业务…

详细整理分层开发步骤!

不点蓝字&#xff0c;我们哪来故事&#xff1f;一、创建数据库&#xff0c;在数据库中创建表二、创建java项目&#xff08;起名要有意义&#xff0c;eg&#xff1a;petSys&#xff09;三、在项目中新建包&#xff0c;包名为&#xff1a;cn.bdqn.petSys.entity四、在cn.bdqn.pet…

ZOJ1101-赌徒【二分查找】

前言 这道题原本老师说是哈希的练习题&#xff0c;结果发现哈希的代码量忒大&#xff0c;然后就用二分了。 正题 有n个赌徒&#xff0c;如果一个赌徒的钱数是其中三个的和那么这个赌徒是赢家&#xff0c;输出最多钱的赢家。 输入输出&#xff08;建议无视&#xff09; Input…

.NET 跨平台界面框架和为什么你首先要考虑再三

现在用 C# 来开发跨平台应用已经有很成熟的方案&#xff0c;即共用非界面代码&#xff0c;而每个操作系统搭配特定的用户界面代码。这个方案的好处是可以直接使用操作系统原生的控件和第三方控件&#xff0c;还能够和操作系统深度集成。 这里的深度集成主要是指一些 Windows 专…

seq2seq中的beam search算法过程

转载自 seq2seq中的beam search算法过程 首先说明在sequence2sequence模型中&#xff0c;beam search的方法只用在测试的情况&#xff0c;因为在训练过程中&#xff0c;每一个decoder的输出是有正确答案的&#xff0c;也就不需要beam search去加大输出的准确率。 假设现在我…