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

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

相关文章

Python从零打造高安全密码管理器

《Python从零打造高安全密码管理器》在数字化时代,每人平均需要管理近百个账号密码,本文将带大家深入剖析一个基于Python的高安全性密码管理器实现方案,感兴趣的小伙伴可以参考一下... 目录一、前言:为什么我们需要专属密码管理器二、系统架构设计2.1 安全加密体系2.2 密码强度策略三、核心功能实现详解

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

Oracle登录时忘记用户名或密码该如何解决

《Oracle登录时忘记用户名或密码该如何解决》:本文主要介绍如何在Oracle12c中忘记用户名和密码时找回或重置用户账户信息,文中通过代码介绍的非常详细,对同样遇到这个问题的同学具有一定的参... 目录一、忘记账户:二、忘记密码:三、详细情况情况 1:1.1. 登录到数据库1.2. 查看当前用户信息1.

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

Java集合中的List超详细讲解

《Java集合中的List超详细讲解》本文详细介绍了Java集合框架中的List接口,包括其在集合中的位置、继承体系、常用操作和代码示例,以及不同实现类(如ArrayList、LinkedList和V... 目录一,List的继承体系二,List的常用操作及代码示例1,创建List实例2,增加元素3,访问元

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,

MySQL修改密码的四种实现方式

《MySQL修改密码的四种实现方式》文章主要介绍了如何使用命令行工具修改MySQL密码,包括使用`setpassword`命令和`mysqladmin`命令,此外,还详细描述了忘记密码时的处理方法,包... 目录mysql修改密码四种方式一、set password命令二、使用mysqladmin三、修改u

C#比较两个List集合内容是否相同的几种方法

《C#比较两个List集合内容是否相同的几种方法》本文详细介绍了在C#中比较两个List集合内容是否相同的方法,包括非自定义类和自定义类的元素比较,对于非自定义类,可以使用SequenceEqual、... 目录 一、非自定义类的元素比较1. 使用 SequenceEqual 方法(顺序和内容都相等)2.

电脑密码怎么设置? 一文读懂电脑密码的详细指南

《电脑密码怎么设置?一文读懂电脑密码的详细指南》为了保护个人隐私和数据安全,设置电脑密码显得尤为重要,那么,如何在电脑上设置密码呢?详细请看下文介绍... 设置电脑密码是保护个人隐私、数据安全以及系统安全的重要措施,下面以Windows 11系统为例,跟大家分享一下设置电脑密码的具体办php法。Windo