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

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

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

Java基础回顾系列-第六天-Java集合

Java基础回顾系列-第六天-Java集合 集合概述数组的弊端集合框架的优点Java集合关系图集合框架体系图java.util.Collection接口 List集合java.util.List接口java.util.ArrayListjava.util.LinkedListjava.util.Vector Set集合java.util.Set接口java.util.HashSetjava

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(

java集合的概述

集合就是一个容器,我们可以把多个对象放入的容器中。就像水杯(假设容量可以不断扩大)一样,你可以往水杯中不断地添加水,既然是水杯,你就不能往里添加沙子,也就是说集合中添加的对象必须是同一个类型的(引用类型,而不能是基本类型)。 看到集合的介绍会让我们的想起数组,那么集合和数组有什么区别呢? 首先,数组的大小是固定的,而集合理论上大小是不限的。 其次,数组既可以存储基本数据类型的数据,也可以存储

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密

超级 密码加密 解密 源码,支持表情,符号,数字,字母,加密 可以将表情,动物,水果,表情,手势,猫语,兽语,狗语,爱语,符号,数字,字母,加密和解密 可以将文字、字母、数字、代码、标点符号等内容转换成新的文字形式,通过简单的文字以不同的排列顺序来表达不同的内容 源码截图: https://www.httple.net/152649.html