当前位置: 首页 > article >正文

蓝桥杯基础--模拟

目录1. 模拟算法简介2. 例题2.1扫雷2.2灌溉2.3回文日期在蓝桥杯以及各种编程竞赛中有一种题型几乎每次都会出现它不需要你掌握多么高深复杂的数据结构比如线段树、图论也不需要你推导晦涩的数学公式它考验的纯粹是你的“代码实现能力”和“细心程度”。这种题型我们通常称之为“模拟”。今天我们就来详细聊聊模拟算法并结合三道经典的蓝桥杯真题带你掌握应对模拟题的技巧。1. 模拟算法简介模拟Simulation顾名思义就是“题目怎么说你就怎么做”。模拟题的核心特征是题目会给你一套非常明确的规则、流程或者操作步骤你需要做的就是用代码把这个过程一步一步地“翻译”出来。计算机的优势在于计算速度极快且不会出错我们要利用这一优势让计算机去重现题目中描述的物理过程或逻辑流程。虽然模拟题在思维难度上通常不大但往往是比赛中最容易让人“翻车”的题型。因为模拟题通常具有以下特点细节繁多可能会有各种边界条件和特殊情况需要处理。代码量大流程一旦复杂嵌套的 if-else 和循环就会非常多容易写错或者漏掉条件。状态依赖很多模拟过程是按时间推进的当前状态往往依赖于上一个状态状态更新时的顺序极其重要。做好模拟题的秘诀只有两个字细心。在动手敲代码之前一定要先在草稿纸上把流程图或者状态变化画清楚理清变量的更新顺序然后再开始编写。2. 例题下面我们通过三道不同类型的蓝桥杯真题来看看模拟题在实战中是如何考察的。2.1扫雷https://www.lanqiao.cn/problems/549/learning/?page1first_category_id1problem_id549思路解析这道题是经典的二维数组模拟。题目要求我们根据给定的地雷分布计算出每个非地雷格子周围一圈也就是常见的九宫格区域有多少颗地雷。 对于这种题最直白的方法就是遍历整个二维矩阵。当我们遇到一个格子时 如果是地雷值为1我们就按题目要求或者为了方便标记将结果标记为9。 如果不是地雷我们就再写两层小循环遍历它周围3乘3的区域统计地雷的个数。 这段代码中有一个非常精妙的防越界技巧在内层循环中使用了 max 和 min 函数。比如_i的范围是max(1, i - 1)到min(n, i 1)这样就算当前格子在矩阵的最边缘也不会发生数组越界报错。#include bits/stdc.h using namespace std; const int N 110; int mp[N][N], ans[N][N]; int main() { int n, m; cin n m; for(int i 1; i n; i) { for(int j 1; j m; j) { cin mp[i][j]; } } for(int i 1; i n; i) { for(int j 1; j m; j) { if(mp[i][j] 1) { ans[i][j] 9; continue; } for(int _i max(1, i - 1); _i min(n, i 1); _i) { for(int _j max(1, j - 1); _j min(m, j 1); _j) { if(mp[_i][_j]) ans[i][j]; } } } } for(int i 1; i n; i) { for(int j 1; j m; j) { cout ans[i][j] ; } cout \n; } return 0; }2.2灌溉https://www.lanqiao.cn/problems/551/learning/?page1first_category_id1problem_id551思路解析这是一道非常经典的状态推演模拟题。水管每分钟都会向上下左右四个方向蔓延。我们需要模拟这个蔓延的过程持续 k 分钟。 这里的核心考点是状态的隔离。如果我们在原来的矩阵上直接修改把没水的改成有水那么在同一分钟内刚刚被水蔓延到的新格子可能紧接着又会向外蔓延这就导致了一分钟蔓延了多步的错误。 为了解决这个问题代码中使用了两个矩阵mp用来保存当前分钟的初始状态ans用来记录蔓延后的新状态。每次遍历mp找到有水的地方将周围的格子在ans中标记为有水。一分钟结束后再把ans的状态同步回mp准备下一分钟的模拟。参考代码#include bits/stdc.h using namespace std; const int N 110; bool mp[N][N], ans[N][N]; int main() { int n, m, t; cin n m; cin t; for(int i 1; i t; i) { int x, y; cin x y; mp[x][y] 1; ans[x][y] 1; } int k; cin k; while(k--) { for(int i 1; i n; i) { for(int j 1; j m; j) { if(mp[i][j]) ans[i][j] ans[i - 1][j] ans[i 1][j] ans[i][j - 1] ans[i][j 1] 1; } } for(int i 1; i n; i) { for(int j 1; j m; j) { mp[i][j] ans[i][j]; } } } int ret 0; for(int i 1; i n; i) { for(int j 1; j m; j) { if(mp[i][j]) ret; } } cout ret \n; return 0; }2.3回文日期https://www.lanqiao.cn/problems/498/learning/?page1first_category_id1problem_id498思路解析这是一道非常经典的日期模拟题。题目要求找出一个给定日期之后的下一个回文日期以及下一个满足 ABABBABA 格式的特殊回文日期。 如果一天一天地往后加还需要处理复杂的进位和闰年判断既容易超时又极其容易写错。 换一种更聪明的模拟思路既然是回文日期前四位年份直接决定了后四位月日。所以我们大可不必一天一天枚举直接从给定的年份开始向下枚举年份。 对于每一个年份我们通过反转拼凑出对应的8位回文日期然后判断这个日期是否比输入的日期 n 大。是否是一个合法的真实日期利用打表的 days 数组和闰年判断函数 isleapYear。 如果是合法日期我们再通过简单的数学运算分离出A和B判断是否满足 ABABBABA 格式即可。这样不仅代码逻辑清晰而且运行速度极快。参考代码#include bits/stdc.h using namespace std; int days[13] {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}; bool isleapYear(int year) { return (year % 4 0 year % 100 ! 0) || (year % 400 0); } bool checkDate(int year, int month, int day) { if(month 1 || month 12 || day 1) return false; if(month ! 2) return day days[month]; if(isleapYear(year)) return day 29; return day 28; } int main() { int n; cin n; bool found1 false, found2 false; int startYear n / 10000; for(int i startYear; i 9999; i) { int date i * 10000 (i % 10) * 1000 (i / 10 % 10) * 100 (i / 100 % 10) * 10 (i / 1000); if(date n) continue; int month (date / 100) % 100; int day date % 100; if(checkDate(i, month, day)) { if(!found1) { cout date \n; found1 true; } int A1 i /1000; int B1 (i / 100) % 10; int A2 (i / 10) % 10; int B2 i % 10; if(!found2 A1 A2 B1 B2 A1 ! B1) { cout date \n; found2 true; } } if(found1 found2) break; } return 0; }本章完。

相关文章:

蓝桥杯基础--模拟

目录 1. 模拟算法简介 2. 例题 2.1扫雷 2.2灌溉 2.3回文日期 在蓝桥杯以及各种编程竞赛中,有一种题型几乎每次都会出现,它不需要你掌握多么高深复杂的数据结构(比如线段树、图论),也不需要你推导晦涩的数学公式&a…...

单片机实战:红外遥控信号解码与智能控制(含完整代码)

1. 红外遥控信号解码的基础原理 红外遥控技术在我们日常生活中随处可见,从电视遥控器到空调控制器,都离不开这项看似简单却非常实用的技术。作为一名嵌入式开发者,掌握红外信号解码是必备技能之一。今天我就来分享一下如何用单片机实现红外遥…...

AI的记忆问题解决了!最强记忆基准99%的准确率

AI的记忆能力正在迎来一次重大的飞跃。Supermemory团队近期公布了一项研究成果,他们构建的一个实验性AI智能体流程,在LongMemEval基准测试中达到了接近99%的准确率。团队表示这是智能体记忆前沿的新突破。智能体的记忆问题也许完全解决了(Age…...

并网逆变器自适应控制:基于阻抗测量的参数辨识与PR控制器自整定

并网逆变器自适应控制:基于阻抗测量的参数辨识与PR控制器自整定 一、 引言与系统架构 在弱电网环境下,电网阻抗(主要是线路阻抗和变压器漏抗)并非恒定。当电网阻抗突变(如微电网孤岛切换、大负载投切)时,传统固定参数的并网逆变器可能面临稳定性下降、谐振甚至失稳的风…...

M10嵌入式开发:Zynq PL-PS协同实现信号I/O与寄存器控制

1. 项目概述M10Examples 是 PulseRain 公司为其 M10 嵌入式开发板配套提供的官方示例代码集合。该系列示例并非通用型软件库,而是面向特定硬件平台(M10 board)的底层驱动验证与功能演示工程,其核心目标是:为硬件工程师…...

FLUX.1-dev效果验证:第三方评测机构对120亿参数模型的真实打分

FLUX.1-dev效果验证:第三方评测机构对120亿参数模型的真实打分 1. 项目背景与评测意义 最近开源社区最热门的话题之一,就是FLUX.1-dev模型的发布。这个拥有120亿参数的巨型文本生成图像模型,号称能够达到"影院级光影质感"的效果。…...

若依前后端分离版实现MQTT消息实时推送

1. MQTT协议与若依框架的完美结合 MQTT协议就像物联网世界的"短信系统",专为设备间通信设计。它最大的特点是轻量级和高效率,特别适合网络条件不稳定的场景。想象一下家里的智能设备——温度传感器每隔几秒就要上报数据,如果每次通…...

揭秘MCP Sampling接口RT飙升300%的真相:从gRPC拦截器到异步缓冲的7层调用链深度剖析

第一章:MCP Sampling接口性能问题的全景认知MCP(Model Control Protocol)Sampling接口是现代AI服务中承担实时采样请求调度与响应的核心通道,其性能表现直接影响端到端推理延迟、吞吐稳定性及资源利用率。当采样请求量突增或模型配…...

集团数字化建设里程碑:DMS/TMS与LIMS系统全面启动,赋能质量管理体系

在生物医药领域,每一份报告、每一组数据,都承载着药品安全与有效的核心承诺。作为您研发道路上值得信赖的第三方检测伙伴,我们深知:可靠的数据不仅源于精密仪器,更源于无懈可击的质量管理体系。近日,集团数…...

JS射线法实战:5分钟搞定电子围栏与快递区域判断(附完整代码)

JS射线法实战:5分钟搞定电子围栏与快递区域判断(附完整代码) 当你在外卖App上输入地址时,系统如何瞬间判断是否在配送范围内?共享单车的电子围栏怎样精准识别停车区域?这些看似简单的功能背后,都…...

163MusicLyrics:一站式音乐歌词获取与管理工具完全指南

163MusicLyrics:一站式音乐歌词获取与管理工具完全指南 【免费下载链接】163MusicLyrics Windows 云音乐歌词获取【网易云、QQ音乐】 项目地址: https://gitcode.com/GitHub_Trending/16/163MusicLyrics 想要轻松获取网易云音乐和QQ音乐的歌词吗?…...

新手也能搞定的1kHz正弦波发生器:用运放和文氏电桥从仿真到洞洞板的完整避坑指南

新手也能搞定的1kHz正弦波发生器:从理论到实践的完整指南 第一次尝试制作正弦波发生器时,我盯着示波器上扭曲的波形发呆——明明仿真时一切正常,怎么实物电路就完全不听使唤?这种挫败感可能每个电子爱好者都经历过。本文将带你从零…...

全球UV打印机市场洞察:规模增长与竞争格局演变

QYResearch调研显示,2025年全球UV打印机市场规模约达15.16亿美元,预计2032年将攀升至21.51亿美元,2026 - 2032期间年复合增长率(CAGR)为5.2%。从细分市场看,平板式UV打印机在装饰装潢领域表现突出&#xff…...

CH592/CH582触摸按键开发实战:从官方例程到自定义按键(附完整代码)

CH592/CH582触摸按键开发实战:从官方例程到自定义按键(附完整代码) 在嵌入式设备的人机交互设计中,触摸按键因其简洁美观、防水防尘等优势,正逐步取代传统机械按键。沁恒微电子的CH592/CH582系列蓝牙MCU内置了高性能的…...

GitHub Trending榜首:Python Agentic RAG企业级落地指南

文章目录前言一、传统RAG为啥不够用了?就像只会翻字典的翻译官二、Agentic RAG的核心架构:不是一个人战斗,而是一个团队1. 规划师(Planner Agent)2. 执行员(Executor Agents)3. 通讯员&#xff…...

别再混淆了!一文搞懂PyTorch中torch.cat()与torch.stack()的区别

别再混淆了!一文搞懂PyTorch中torch.cat()与torch.stack()的区别 刚接触PyTorch时,面对各种张量操作函数总让人眼花缭乱。特别是torch.cat()和torch.stack()这两个看似相似的拼接函数,很多初学者都会困惑它们到底有什么区别。今天我们就来彻底…...

BooruDatasetTagManager:从零到精通的智能图像标注全攻略

BooruDatasetTagManager:从零到精通的智能图像标注全攻略 【免费下载链接】BooruDatasetTagManager 项目地址: https://gitcode.com/gh_mirrors/bo/BooruDatasetTagManager 在AI模型训练的世界中,数据标注往往是决定成败的关键环节。传统的手动标…...

K8s节点死活加不进来?别急着重装,先检查这几个残留文件和端口(附一键清理脚本)

K8s节点加入失败的深度排障指南:从残留文件到端口占用的系统化解决方案 遇到Kubernetes节点死活加不进集群的情况,很多运维工程师的第一反应是重装系统——这就像用核弹解决蚊子问题,既低效又破坏性极强。实际上,90%的节点加入失败…...

手把手教你:用lychee-rerank-mm给爬虫数据打分,绿色高分直接采用

手把手教你:用lychee-rerank-mm给爬虫数据打分,绿色高分直接采用 1. 为什么需要给爬虫数据打分? 做过数据抓取的开发者都知道,爬虫获取的数据往往鱼龙混杂。你可能抓取了上百个网页,但真正有价值的内容可能只有一小部…...

棋盘多项式-进阶题17

棋盘多项式 题目 问题描述求出区间[a,b]中所有整数的质因数分解。输入说明 输入两个整数a&#xff0c;b。2<a<b<10000输出说明 每行输出一个数的分解&#xff0c;形如ka1a2a3…(a1<a2<a3…&#xff0c;k也是从小到大的)(具体可看范例)输入范例 3 10输出范例 33 …...

MOSFET五大失效机理与工程防护指南

1. MOS管失效机理深度解析&#xff1a;从雪崩击穿到栅极过压的工程实践视角MOSFET作为现代电力电子系统的核心开关器件&#xff0c;因其高输入阻抗、低驱动功耗、快速开关特性及优异的导通电阻&#xff08;RDS(on)&#xff09;表现&#xff0c;被广泛应用于DC-DC变换器、电机驱…...

Qwen3-ASR-1.7B歌唱识别专项:流行歌曲歌词转录挑战

Qwen3-ASR-1.7B歌唱识别专项&#xff1a;流行歌曲歌词转录挑战 1. 引言 你有没有试过&#xff0c;在KTV里唱完一首歌&#xff0c;想回味一下自己唱了什么&#xff0c;却发现歌词APP里只有原唱版本&#xff0c;自己那版根本搜不到&#xff1f;或者&#xff0c;作为一个音乐爱好…...

OFA图像描述模型Node.js环境配置:构建高性能图像描述API服务

OFA图像描述模型Node.js环境配置&#xff1a;构建高性能图像描述API服务 最近有不少朋友在问&#xff0c;怎么把那些厉害的AI模型集成到自己的Web应用里。特别是像OFA这种能看懂图片并生成描述的模型&#xff0c;如果能做成一个API服务&#xff0c;那应用场景就太广了——从电…...

威联通NAS+Docker Compose:打造全能媒体中心实战指南

1. 为什么选择威联通NASDocker Compose搭建媒体中心 最近几年&#xff0c;家庭媒体中心的概念越来越火。作为一个折腾过多套方案的资深玩家&#xff0c;我最终选择了威联通NASDocker Compose的组合。这套方案最大的优势在于灵活性和可扩展性——你可以像搭积木一样&#xff0c;…...

论文图表救急包:5分钟学会AI/PSD转EPS矢量图的正确姿势

科研图表格式转换实战&#xff1a;从PSD到EPS的矢量图高效处理指南 当你在深夜赶完论文最后一组数据图表&#xff0c;满心欢喜地点击投稿按钮时&#xff0c;系统却无情地弹出一条错误提示&#xff1a;"仅接受EPS矢量图格式"——这种场景几乎每位科研工作者都经历过。…...

从Firebase迁移到Supabase:一个前端开发者的真实踩坑与平滑过渡指南

从Firebase迁移到Supabase&#xff1a;一个前端开发者的真实踩坑与平滑过渡指南 作为一名长期使用Firebase的前端开发者&#xff0c;我最近完成了一个中型项目从Firebase到Supabase的完整迁移。这次迁移并非一时兴起&#xff0c;而是经过深思熟虑的技术决策过程。本文将分享我在…...

[知识自由获取]:智能适配技术驱动的内容访问优化解决方案

[知识自由获取]&#xff1a;智能适配技术驱动的内容访问优化解决方案 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 3个维度破解学术与信息获取壁垒 一、痛点剖析&#xff1a;数字时…...

OpenClaw故障自愈方案:QwQ-32B监控脚本异常并自动恢复

OpenClaw故障自愈方案&#xff1a;QwQ-32B监控脚本异常并自动恢复 1. 为什么需要故障自愈能力 上周我的爬虫脚本又崩了——这已经是本月第三次在凌晨两点崩溃。当我早上打开电脑时&#xff0c;发现数据采集任务已经停滞了6小时&#xff0c;错过了关键的黄金采集时段。这种经历…...

数据质量评估:清洗前后的量化对比方法

数据质量评估:清洗前后的量化对比方法 关键词:数据质量评估、数据清洗、量化对比、数据准确性、数据完整性 摘要:本文主要探讨了数据质量评估中清洗前后的量化对比方法。首先介绍了数据质量评估和清洗的背景知识,接着详细解释了数据质量评估的核心概念,包括准确性、完整性…...

用Flink Table API实现流批一体:订单数据SQL化处理与可视化实战

Flink Table API实战&#xff1a;滴滴订单流批一体处理与实时可视化全流程解析 在当今数据驱动的商业环境中&#xff0c;实时数据处理能力已成为企业核心竞争力的关键组成部分。滴滴等出行平台每天产生数以亿计的订单数据&#xff0c;如何高效处理这些实时流数据&#xff0c;同…...