蓝桥杯刷题冲刺 | 倒计时13天
作者:指针不指南吗
专栏:蓝桥杯倒计时冲刺🐾马上就要蓝桥杯了,最后的这几天尤为重要,不可懈怠哦🐾
文章目录
- 1.母牛的故事
- 2.魔板
1.母牛的故事
-
题目
链接: [递归]母牛的故事 - C语言网 (dotcpp.com)
有一头母牛,它每年年初生一头小母牛。每头小母牛从第四个年头开始,每年年初也生一头小母牛。请编程实现在第n年的时候,共有多少头母牛?
输入格式
输入数据由多个测试实例组成,每个测试实例占一行,包括一个整数n(0<n<55),n的含义如题目中描述。
n=0表示输入数据的结束,不做处理。输出格式
对于每个测试实例,输出在第n年的时候母牛的数量。
每个输出占一行。样例输入
2 4 5 0
样例输出
2 4 6
-
第一次 AC 50%
#include<bits/stdc++.h> using namespace std;int main() {int n;while(cin>>n){int sum=0;if(n==0)return 0;for(int i=1;i<=n;i++){if(i<=4)sum+=1;else sum+=i-3;}cout<<sum<<endl;}return 0; }
枚举了前几个数,找的规律是错的
-
第二次 AC 50% + 超时 50%
#include<bits/stdc++.h> using namespace std;int f(int n) {if(n<=4)return n;return f(n-2)+f(n-3)+f(n-4); }int main() {int n;while(scanf("%d",&n)){if(n==0)return 0;cout<<f(n)<<endl;}return 0; }
递归+规律,第二次递归的规律又找错了
-
第三次 AC 50% + 50% 超时
#include<bits/stdc++.h> using namespace std;int f(int n) {if(n<4)return n;return f(n-1)+f(n-3); }int main() {int n;while(scanf("%d",&n)&&n) //记住这个,当输入0时,跳出循环{cout<<f(n)<<endl;}return 0; }
这次 规律对,但还是 超时
-
第四次 AC 100%
#include<bits/stdc++.h> using namespace std;int main() {int n;while(scanf("%d",&n)&&n){int a[60];a[1]=1,a[2]=2,a[3]=3;for(int i=4;i<=n;i++) //使用数组递归{a[i]=a[i-1]+a[i-3];}cout<<a[n]<<endl;}return 0; }
-
反思
找规律的题:
不要局限在前后相邻的数,不要只找一组,就直接把规律定下来,多找几组
找规律题中+递归,一开始根本没有往这方面想
How
- 找规律,发散思维,很有可能有递归,看看前后几个数之间的关系
- 递归函数,可能会超时,考试的时候,就直接使用 数组来代替函数
2.魔板
-
题目
链接: 魔板 - C语言网 (dotcpp.com)
在魔方风靡全球之后不久,Rubik先生发明了它的简化版――魔板。魔板 由8个同样大小的方块组成,每个方块颜色均不相同,可用数字1-8分别表示。任一时刻魔板的状态可用方块的颜色序列表示:从魔板的左上角开始,按顺时针方 向依次写下各方块的颜色代号,所得到的数字序列即可表示此时魔板的状态。例如,序列(1,2,3,4,5,6,7,8)表示魔板状态为:
1 2 3 4
8 7 6 5
对于魔板,可施加三种不同的操作,具体操作方法如下:
A: 上下两行互换,如上图可变换为状态87654321
B: 每行同时循环右移一格,如上图可变换为41236785
C: 中间4个方块顺时针旋转一格,如上图可变换为17245368
给你魔板的初始状态与目标状态,请给出由初态到目态变换数最少的变换步骤,若有多种变换方案则取字典序最小的那种。输入格式
每组测试数据包括两行,分别代表魔板的初态与目态。
输出格式
对每组测试数据输出满足题意的变换步骤。
样例输入
12345678 17245368 12345678 82754631
样例输出
C AC
-
第一次 AC 0%
#include<bits/stdc++.h> using namespace std;const int N=1010; int d[N];string FA(string a) {string b=a;a[0]=b[4],a[1]=b[5],a[2]=b[6],a[3]=b[7];a[4]=b[0],a[5]=b[1],a[6]=b[2],a[7]=b[3];return a; }string FB(string a) {string b=a;a[0]=b[3],a[1]=b[0],a[2]=b[1],a[3]=b[2],a[4]=b[6];a[5]=b[5],a[6]=b[4],a[7]=b[7];return a; }string FC(string a) {string b=a;a[0]=b[0],a[1]=b[5],a[2]=b[1],a[3]=b[3];a[4]=b[4],a[5]=b[6],a[6]=b[2],a[7]=b[7];return a; } void bfs(string st,string over) {queue<string> q;q.push(st);unordered_map<string,string> mp;while(q.size()){auto now=q.front();q.pop();if(now==over){cout<<mp[now]<<endl;return ;}string ss;for(int i=1;i<=3;i++){switch(i){case 1:ss=FA(now);if(!mp.count(ss)){q.push(ss);mp[ss]=mp[now]+'A';}break;case 2:ss=FB(now);if(!mp.count(ss)){q.push(ss);mp[ss]=mp[now]+'B';}break;case 3:ss=FB(now);if(!mp.count(ss)){q.push(ss);mp[ss]=mp[now]+'C';}break;}}}}int main() {string a,b;while(cin>>a>>b){bfs(a,b);}return 0; }
一开始,框架都写出来,但是输出 转换的路径写不出来,忘记咋写了
好像是倒推,前几天写过,题解中的是用的 STL 里面的 map
哪里出错了,还没有看出来,他没有输出
-
题解
#include<bits/stdc++.h> using namespace std; // 定义两个变量s和f,代表起点状态和终点状态,其值由输入读入 string s, f; // 操作A函数,将输入状态x按照操作A的规则进行变换 string A(string x) {string s = x;for (int i = 0; i < 4; i++) {swap(s[i], x[7 - i]);swap(s[i + 4], x[3 - i]);}return s; } // 操作B函数,将输入状态x按照操作B的规则进行变换 string B(string x) {string s = x;s[0] = x[3], s[1] = x[0];s[2] = x[1], s[3] = x[2];s[4] = x[5], s[5] = x[6];s[6] = x[7], s[7] = x[4];return s; } // 操作C函数,将输入状态x按照操作C的规则进行变换 string C(string x) {string s = x;s[1] = x[6], s[2] = x[1];s[5] = x[2], s[6] = x[5];return s; } // 广搜函数,使用map进行去重,记录操作序列 void bfs() {unordered_map<string, string>mp; // 哈希表,用于存储操作序列queue<string>q; // 队列,用于存储待搜索状态q.push(s); // 将初始状态入队while (!q.empty()) { // 只要队列不为空,就继续搜索string now = q.front(); // 取出队首元素q.pop(); // 将队首元素出队if (now == f) { // 当达到终点状态,输出操作序列cout << mp[now] << endl;return; // 搜索结束}string ts; // 操作后的状态// 按照题目要求,A、B、C操作依次搜索,保证字典序最小for (int i = 0; i < 3; i++) { // 依次搜索ABC操作,保证字典序最小switch (i) {case 0: // A操作ts = A(now); // 对当前状态进行A操作if (!mp.count(ts)) { // 如果操作后的状态不在哈希表中q.push(ts); // 将操作后的状态入队mp[ts] = mp[now] + 'A'; // 更新哈希表,存储操作序列}break;case 1: // B操作ts = B(now); // 对当前状态进行B操作if (!mp.count(ts)) { // 如果操作后的状态不在哈希表中q.push(ts); // 将操作后的状态入队mp[ts] = mp[now] + 'B';// 更新哈希表,存储操作序列}break;case 2://C操作ts = C(now); // 对当前状态进行B操作if (!mp.count(ts)) { // 如果操作后的状态不在哈希表中q.push(ts); // 将操作后的状态入队mp[ts] = mp[now] + 'C';// 更新哈希表,存储操作序列}break;}}} } int main() {while (cin >> s >> f) {bfs();}return 0; }
-
反思
通过三种不同的转化状态+最少变化步骤,我们可以确定是 BFS
对于我来说,这个题的难点不在于确定最少的步数是多少,而是输出路径
-
学到了使用 switch 执行不同的函数,我差点就使用函数数组了TvT
-
借助了 map 去重+输出路径,学到了
之前我以为路径都必须倒推,很麻烦,map 真的好用
我们再研究一下,路径的记录,再刷一两道题这个类型的题
-
相关文章:
蓝桥杯刷题冲刺 | 倒计时13天
作者:指针不指南吗 专栏:蓝桥杯倒计时冲刺 🐾马上就要蓝桥杯了,最后的这几天尤为重要,不可懈怠哦🐾 文章目录1.母牛的故事2.魔板1.母牛的故事 题目 链接: [递归]母牛的故事 - C语言网 (dotcpp.c…...
MIPI D-PHYv2.5笔记(5) -- 不同的PHY配置方式
声明:作者是做嵌入式软件开发的,并非专业的硬件设计人员,笔记内容根据自己的经验和对协议的理解输出,肯定存在有些理解和翻译不到位的地方,有疑问请参考原始规范看 规范5.7章节列举了一些常见的PHY配置,但实…...
【周末闲谈】文心一言,模仿还是超越?
个人主页:【😊个人主页】 系列专栏:【❤️周末闲谈】 周末闲谈 ✨第一周 二进制VS三进制 文章目录周末闲谈前言一、背景环境二、文心一言?(_)?三、文心一言的优势?😗😗😗四、文心一…...
《一“企”谈》 | 「佛山市政」:携手企企通,让采购业务数智化
近日,国家施工总承包壹级企业「佛山市市政建设工程有限公司」(以下简称“佛山市政”)正积极布局数字化建设工作,基于采购业务数智化,携手企企通打造了SaaS采购云平台。 01、岭南建筑强企 匠心铸造精品 …...
Spark运行架构
目录 1 运行架构 2 核心组件 2.1 Driver 2.2 Executor 2.3 Master & Worker 2.4 ApplicationMaster 3 核心概念 3.1 Executor 与 Core 3.2 并行度( Parallelism) 3.3 有向无环图( DAG) 4 提交流程 …...
基于卷积神经网络CNN的水果分类预测,卷积神经网络水果等级识别
目录 背影 卷积神经网络CNN的原理 卷积神经网络CNN的定义 卷积神经网络CNN的神经元 卷积神经网络CNN的激活函数 卷积神经网络CNN的传递函数 卷积神经网络CNN水果分类预测 基本结构 主要参数 MATALB代码 结果图 展望 背影 现在生活,为节能减排,减少电能…...
Spring Boot 框架总结
Spring Boot 框架总结 1. springboot的引言 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的 初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不 再需要定义样板化的配置。通过这种方式࿰…...
【数据结构】第五站:带头双向循环链表
目录 一、链表的八种结构 二、带头双向循环链表的实现 1.链表的定义 2.链表的接口定义 3.接口的具体实现 三、带头双向循环链表的完整代码 四、顺序表和链表的区别 一、链表的八种结构 我们已经知道链表可以有以下三种分法 而这三种结构又可以排列组合,形成八…...
Springboot生成二维码
Springboot生成二维码整合 我们使用两种方式,去生成二维码,但是其实,二维码的生成基础,都是zxing包,这是Google开源的一个包,第一种是使用原始的zxing方式去实现,第二种是使用hutool来实现&…...
“独裁者”何小鹏,再造小鹏汽车
文丨智能相对论 作者丨沈浪 如果没有何小鹏,小鹏汽车将失去灵魂。 2014年,夏珩、何涛等人在广州组建小鹏汽车(当时还叫“橙子汽车”),何小鹏还只是股权投资人。 夏珩、何涛原任职于广汽,负责新能源汽车…...
数据结构 | 泛型 | 擦除机制| 泛型的上界
目录 编辑 1.泛型 1.1Object类引出泛型概念 2.泛型语法 2.1泛型编写代码 3.泛型的机制 3.1擦除机制 4.泛型的上界 4.1泛型上界的语法 4.2泛型上界的使用 5.泛型方法 5.1泛型方法语法 5.2泛型方法的使用 1.泛型 一般的类和方法中,只能使用具体的代码…...
C++拷贝构造函数(复制构造函数)详解
拷贝和复制是一个意思,对应的英文单词都是copy。对于计算机来说,拷贝是指用一份原有的、已经存在的数据创建出一份新的数据,最终的结果是多了一份相同的数据。例如,将 Word 文档拷贝到U盘去复印店打印,将 D 盘的图片拷…...
python学习——多线程
python学习——多线程概念python中线程的开发线程的启动线程的退出和传参threading的属性和方法threading实例的属性和方法多线程daemon线程和non-demone线程daemon线程的应用场景线程的jointhreading.local类线程的延迟执行:Timer线程同步Event 事件Lock ——锁加锁…...
SAP 系统中过账码or记账码
SAP中过账码和记账码是指同一个事物。 在实际业务中,记账码就是只有“借”和“贷”, 而SAP中Posting Code肩负着更多的任务: 1)界定科目类型, 2)借贷方向, 3)凭证输入时画面上的字…...
【FreeRTOS(一)】FreeRTOS新手入门——初识FreeRTOS
初识FreeRTOS一、实时操作系统概述1、概念2、RTOS的必要性3、RTOS与裸机的区别4、FreeRTOS的特点二、FreeRTOS的架构三、FreeRTOS的代码架构一、实时操作系统概述 1、概念 RTOS:根据各个任务的要求,进行资源(包括存储器、外设等)…...
Python中 __init__的通俗解释是什么?
__init__是Python中的一个特殊方法,用于在创建对象时初始化对象的属性。通俗来讲,它就像是一个构造函数,当我们创建一个类的实例时,__init__方法会被自动调用,用于初始化对象的属性。 举个例子,如果我们定义…...
网友真实面试总结出的自动化测试面试题库
目录 常规问题 手工测试部 自动化测试 自动化测试面试题2:selenium篇 常规问题 1、如何快速深入的了解移动互联网领域的应用 (答案:看http协议 restful api知识 json加1分) 2、对xx应用自己会花多久可以在业务上从入门到精通&…...
2023 年最佳 C++ IDE
文章目录前言1. Visual Studio2. Code::Blocks3. CLion4. Eclipse CDT(C/C 开发工具)5. CodeLite6. Apache NetBeans7. Qt Creator8. Dev C9. C Builder10. Xcode11. GNAT Programming Studio12. Kite总结前言 要跟踪极佳 IDE(集成开发环境&…...
在Ubuntu上使用VSCode编译MySQL Connector/C连接库
首先下载并解压MySQL Connector/C源码,然后执行以下步骤: 1、安装MySQL Connector/C依赖:在终端中输入以下命令来安装MySQL Connector/C的依赖项: sudo apt-get install build-essential cmake 2、下载并解压MySQL Connector/C源…...
单声道数字音频放大器AD87589
AD87589是一种集成音频系统解决方案,嵌入数字音频处理、功率级放大器和立体声2Vrms线路驱动器。 AD87589具有可编程转换速率控制的输出缓冲器,可直接驱动一个(单声道)或两个(立体声)扬声器。此外࿰…...
网络的UDP协议和TCP协议
协议:数据在网络中的传输规则,常见的协议有 UDP协议和TCP协议 协议:计算机网络中,连接和通信的规则被称为网络通信协议 UDP协议:用户数据报协议,是面向无连接通信协议,速度快,有大小…...
【JaveEE】多线程之阻塞队列(BlockingQueue)
目录 1.了解阻塞队列 2.生产者消费者模型又是什么? 2.1生产者消费者模型的优点 2.1.1降低服务器与服务器之间耦合度 2.1.2“削峰填谷”平衡消费者和生产的处理能力 3.标准库中的阻塞队列(BlockingQueue) 3.1基于标准库(Bloc…...
分布式ELK日志监控系统环境搭建
文章目录1.1为什么需要监控项目日志1.2ELK日志监控系统介绍1.3ELK的工作流程1.4ELK环境搭建1.4.1Elasticsearch的安装1.4.2Kibana的安装1.4.3Logstash的安装1.4.4数据源配置1.4.5日志监测测试1.4.6日志数据可视化展示1.1为什么需要监控项目日志 项目日志是记录项目运行过程中产…...
【数据结构刷题集】链表经典习题
😽PREFACE🎁欢迎各位→点赞👍 收藏⭐ 评论📝📢系列专栏:数据结构刷题集🔊本专栏涉及到题目是数据结构专栏的补充与应用,只更新相关题目,旨在帮助提高代码熟练度&#x…...
JavaSE(3.27) 异常
学习不要眼高手低,学习是一点点积累的。即使你现在很菜,坚持学一个学期不会差的!只要花时间学习,每天都是进步的,这些进步可能你现在看不到,但是不要小瞧了积累效应,30天,60天&#…...
【看门狗】我说的是定时器不是狗啊
单片机在运行中死机了,你或许只能按2下电源键(重启)或1下复位键。 这里简单说一下重启和复位: 从RESET引脚复位,只有MCU复位。而外设看情况,有的可能会有MCU同步复位或者重新初始化。也有可能一些保持复位…...
24万字智慧城市顶层设计及智慧应用解决方案
本资料来源公开网络,仅供个人学习,请勿商用,如有侵权请联系删除。部分资料内容: 4.8 机房消防系统 4.8.1消防系统概况 根据本工程机房消防系统的特殊要求,整个消防系统由火灾报警系统、消防联动系统和气体灭火系统三部…...
跨境电商卖家工具——跨境卫士内容介绍
一、简介 跨境卫士是一款集合多种跨境电商工具的综合软件,由知名跨境电商服务商跨境通开发。跨境卫士可以帮助卖家完成海外物流管理、订单处理、报关报税、市场营销等多项任务,同时还提供数据分析、客户服务、运营管理等一系列支持功能,方便卖…...
Redis 常用基本命令
关于 redis 的常用基本命令 目录 关于 redis 的常用基本命令 1. 关于 key 的操作 2. HyperLogLog 求近似基数 3. 排序相关命令 4. Limit 限制查询 1. 关于 key 的操作 判断某个 key 是否存在 # 格式: exists key exists name# 存在name 返回1 # 不存在name 返回0 查找或…...
【Leetcode】队列的性质与应用
文章目录225. 用队列实现栈示例:提示:分析:题解:622. 设计循环队列示例:提示:分析:题解:225. 用队列实现栈 请你仅使用两个队列实现一个后入先出(LIFO)的栈&…...
wordpress 相关文章 图片/seo广告投放
今天,我们来谈谈一个新仓库应该如何规划!仓库先进先出规划1. 进出从不同的门进行,入库从进仓门进,出库从出仓门出。2. 联单制,每箱设两联单,一联贴箱上,一联放文件夹内,依据入仓时间…...
介绍自己的做的网站/设计本网站
HTML中的JavaScript脚本必须位于<script>与</script>标签之间,JavaScript脚本可被放置在HTML页面的 <body>标签和<head>标签中,这种视情况而定,一般放在<head>标签内。 一<script> 标签 如需在HTML页面…...
网站换空间 百度快照倒退一年多 怎么回事/蒙牛牛奶推广软文
首先简单说一下vue双向数据绑定在实际应用上会有一点异常。 1.比如我想使用一个数组内部数据的改变,直接使用arr[0]‘bbbb’,这样是不会触发数据绑定的。视图不会变化。 2.这个问题就纯是js的问题了。。我们需要把一个json数据的值赋值给另一个ÿ…...
导航网站系统/东莞网络推广公司
图片懒加载有几个重要的点: 1. 图片 的src放到其他属性上,加统一的类名,供选择和 加样式,比如: <img class"pic" alt"加载中" data-src"http://ww1.sinaimg.cn/large/b0b365f5ly1fl8gmghdbsj20qo0bt3zo.jpg&quo…...
网站群怎么做/宁波seo网络推广报价
在Ubuntu中备份svn上传的代码,将备份的文件命名为svn_backup当前时间.dump文件(例svn_backup20100525.dump)1.编写脚本文件(backup.sh)sudo touch backup.sh创建脚本文件,并编辑文件sudo vim backup.sh上图为配置的文件内容,代码如下…...
做百度移动网站点击/视频营销
文章目录传送门什么是数词基数词基数词的单复数序数词数词应用表达[日期/时间]日期年月、日年、月、日时间直接表达间接表达分数小数百分数钱币长度单位重量单位电话号码总结传送门 明翰英语教学系列之方法篇明翰英语教学系列之音标篇明翰英语教学系列之名词篇明翰英语教学系列…...