牛客网考研机试题集合:玛雅人的密码

2023-12-28 18:08

本文主要是介绍牛客网考研机试题集合:玛雅人的密码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

思路是:

将所有移位都列出来,然后检查是否符合要求。

第一次移位后,很容易判断移位后的字符串,

那第二次移位的字符串从哪里来呢(显然来自于第一次移位后的字符串,因此要将前一次的字符串存储起来),而且为了移位次数最少,应该将第二次所有可能的字符串都遍历完,才进行第三次遍历(字符串有来自第二次移动后的字符串)。

 

因此整个过程就是广度优先搜索的思路

注意:

1.移动过程中会出现重复出现过的字符串,显然不需要再对其进行移位,因此不需要进入队列

2.搜索的结束条件是什么?

移动后出现目标字符串,或者队列为空

3.注意 在某一字符串形成所有可能移位的字符串时,注意始终是这一次的原字符串

4.优化,如果原始字符串,都不含有2个2,一个1,一个0,那其无论怎样移位都不会出现2012,这样的数据可以直接输出结果


#include<bits/stdc++.h>
using namespace std;
struct E {string s;int level;E(string s,int level):s(s),level(level) {}
};void bfs(string s,int len);
int main() {int n;string s;while(cin>>n) {cin>>s;int cnt=0;int flag0=0,flag1=0,flag2=0;for(int i=0; i<n; i++) {if(s[i]=='0') {flag0=1;}if(s[i]=='1') {flag1=1;;}if(s[i]=='2') {cnt++;if(cnt>=2) {flag2=1;}}}if(flag0&&flag2&&flag2) {bfs(s,n);} else {cout<<-1<<endl;}}return 0;
}void bfs(string s,int len) {queue<E> q1;map<string,int> map1;q1.push(E(s,0));int flag=0;while(!q1.empty()) {E tmp=q1.front();q1.pop();if(tmp.s.find("2012")==string::npos) {for(int i=0; i<len-1; i++) {swap(tmp.s[i],tmp.s[i+1]);if(map1.count(tmp.s)==0) {map1[tmp.s]=1;q1.push(E(tmp.s,tmp.level+1));}swap(tmp.s[i],tmp.s[i+1]);//特别注意}} else {flag=1;cout<<tmp.level<<endl;break;}}if(q1.empty()==1&&flag==0) {cout<<-1<<endl;}}

 

这篇关于牛客网考研机试题集合:玛雅人的密码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/546802

相关文章

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

Java集合中的链表与结构详解

《Java集合中的链表与结构详解》链表是一种物理存储结构上非连续的存储结构,数据元素的逻辑顺序的通过链表中的引用链接次序实现,文章对比ArrayList与LinkedList的结构差异,详细讲解了链表... 目录一、链表概念与结构二、当向单链表的实现2.1 准备工作2.2 初始化链表2.3 打印数据、链表长

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

PostgreSQL数据库密码被遗忘时的操作步骤

《PostgreSQL数据库密码被遗忘时的操作步骤》密码遗忘是常见的用户问题,因此提供一种安全的遗忘密码找回机制是十分必要的,:本文主要介绍PostgreSQL数据库密码被遗忘时的操作步骤的相关资... 目录前言一、背景知识二、Windows环境下的解决步骤1. 找到PostgreSQL安装目录2. 修改p

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

SpringBoot如何对密码等敏感信息进行脱敏处理

《SpringBoot如何对密码等敏感信息进行脱敏处理》这篇文章主要为大家详细介绍了SpringBoot对密码等敏感信息进行脱敏处理的几个常用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录​1. 配置文件敏感信息脱敏​​2. 日志脱敏​​3. API响应脱敏​​4. 其他注意事项​​总结