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

算法模拟类题目解析

前言最近开始偏系统的从简单到难一步步刷算法题先从模拟题开始下边附带题目与连接感兴趣可刷刷也可看看我的思路。一.字符串展开链接https://ac.nowcoder.com/acm/problem/16644来源牛客网题意输入一个字符串含数字、小写字母和减号以及三个参数 p1、p2、p3。当遇到减号“-”时如果它两边都是小写字母或都是数字且右边字符大于左边就进行“展开”把两边之间的所有字符按顺序或逆序填充进去每个字符重复 p2 次p1 控制填充内容小写、大写或星号p3 控制顺序正序或逆序。如果两边是相邻字符如“a-b”则直接删掉减号如果不满足展开条件如“a-d-d”中的第二个减号则保留原减号。解析作为模拟题目很显然我们要做的就是跟着题目意思进行模拟这种题目怕的主要是漏了题目所给条件导致无法ac这个题意已经根据原题进行精简挑出重点但在原题目中需要好好注意提取题目主要意思进行查缺补漏。下边为我的ac代码#includeiostream #includestring #includectype.h #includealgorithm using namespace std; int panduan(char c) { if(c0c9)return 1; else if(cacz)return 2; return 0; } int main() { int p1,p2,p3; cin p1 p2 p3; string s,ans; cin s; ans; for(int i0;is.size();i) { if(s[i]-s[i-1]s[i1]p11i0(panduan(s[i-1])panduan(s[i1]))) { string sub; sub; for(char js[i-1]1;js[i1];j) { for(int k1;kp2;k) subj; } if(p32) reverse(sub.begin(),sub.end()); anssub; continue; } else if(s[i]-s[i-1]s[i1]p11i0(panduan(s[i-1])panduan(s[i1]))) { string sub; sub; for(char jtolower(s[i-1]1);jtolower(s[i1]);j) { for(int k1;kp2;k) subj; } if(p32) reverse(sub.begin(),sub.end()); anssub; continue; } else if(s[i]-s[i-1]s[i1]p12i0(panduan(s[i-1])panduan(s[i1]))) { string sub; sub; for(char jtoupper(s[i-1]1);jtoupper(s[i1]);j) { for(int k1;kp2;k) subj; } if(p32) reverse(sub.begin(),sub.end()); anssub; continue; } else if(s[i]-s[i-1]s[i1]p13i0(panduan(s[i-1])panduan(s[i1]))) { for(char js[i-1]1;js[i1];j) { for(int k1;kp2;k) ans*; } continue; } anss[i]; } cout ans; return 0; }一开始我没加上这个panduan函数导致我卡在70%的正确率大部分人都是因为忘记-号前后要是同一类型a-z或者是0-9的形式无法AC。代码可能有点复杂了可自行简化但思路大差不差。二.多项式展开链接https://ac.nowcoder.com/acm/problem/16622来源牛客网题意这题就是给你一个多项式从高到低每个次数的系数让你按数学课本上的写法输出。需要注意几个细节第一项如果是正数不要加号系数是 1 或 -1 时不要写那个 1只写符号和 x指数是 1 时不要写 ^1指数是 0 时只输出系数系数为 0 的项直接扔掉。解析上题是题意捕捉上不要遗漏这题是模拟决策上的选择因为负数自带符号我想着怎么调整可以运用但最后给代码搞得很乱也无法ac最后干脆跟着题意分步骤判断符号在输出绝对值。下边为ac代码#includebits/stdc.h using namespace std; int main() { int n; cin n; vectorinta(n5,0); int first0; for(int i1;in1;i) { cin a[i]; if(a[i]0)continue; else if(a[i]0first) { cout ; } else if(a[i]0) { cout -; }if(in1||abs(a[i])!1) cout abs(a[i]); if(a[i]0||a[i]0)first1; if(n-i11) cout x^ n-i1; else if(n-i11) { cout x; } } return 0; }其实这题问题并不多主要注意的就是开头的符号判断其他正常模拟即可。三.机器翻译链接https://ac.nowcoder.com/acm/problem/16589来源牛客网题意这题就是模拟一个固定大小的翻译缓存。每次遇到单词时如果缓存里有就直接用如果没有就要去查词典计数1然后把单词放进缓存。如果缓存满了就把最早放进去的那个单词挤掉。最后输出总共查了多少次词典。解析这一题我第一眼觉得它是队列题但我想用桶数组试试但很显然是我想美了队列方式的做法简单有醒目桶直接乱套了所以还是老老实实的用队列如果对队列知识不熟的可以看看我上一篇文章。下边为ac代码#includebits/stdc.h using namespace std; int main() { int M,N,cnt0; bool a[20000]; queueintq; cin M N; for(int i1;iN;i) { int t; cin t; if(a[t])continue; if(q.size()M) { auto tq.front(); a[q.front()]0; q.pop(); } a[t]1; q.push(t); cnt; } cout cnt; return 0; }这边注意点不多也没有队列是否为空的判断用队列直接模拟即可

相关文章:

算法模拟类题目解析

前言:最近开始偏系统的从简单到难一步步刷算法题,先从模拟题开始,下边附带题目与连接,感兴趣可刷刷也可看看我的思路。 一.字符串展开 链接:https://ac.nowcoder.com/acm/problem/16644 来源:牛客网 题意…...

华为云AI开发认证HCCDA通关指南:从试题解析到实战应用

1. 华为云HCCDA认证:AI开发者的黄金敲门砖 最近两年,AI技术在各行各业的应用越来越广泛,很多开发者都在寻找能够系统学习AI开发的途径。华为云推出的HCCDA(Huawei Cloud Certified Developer Associate)认证&#xff0…...

从黑客攻防角度看网络命令:如何用ping/tracert/nslookup发现网络安全隐患

网络命令的攻防实战:用基础工具发现隐藏的安全威胁 当大多数人还在把ping、tracert这些基础网络命令当作简单的连通性测试工具时,安全工程师已经将它们变成了发现网络威胁的"显微镜"。这些看似简单的命令行工具,在专业的安全分析场…...

MT5 Zero-Shot参数详解:Temperature与Top-P对中文改写多样性的影响

MT5 Zero-Shot参数详解:Temperature与Top-P对中文改写多样性的影响 1. 项目概述 MT5 Zero-Shot Chinese Text Augmentation 是一个基于 Streamlit 和阿里达摩院 mT5 模型构建的本地化 NLP 工具。这个工具专门用于中文句子的语义改写和数据增强,能够在保…...

别再折腾了!保姆级AirSim+UE5.3安装配置指南(附常见编译错误解决)

AirSim与虚幻引擎5.3深度整合:从零搭建自动驾驶仿真环境的完整实践 在自动驾驶技术快速发展的今天,仿真环境已成为算法开发与测试不可或缺的一环。微软开源的AirSim作为一个高度逼真的仿真平台,与虚幻引擎5.3的结合为开发者提供了前所未有的视…...

别只盯着协议!用TC8测试案例深度解读车载网络中的ARP与ICMP:安全与稳定的隐藏关卡

车载以太网底层协议实战:从TC8测试案例看ARP与ICMP的安全设计 当一辆现代汽车以100km/h行驶时,其车载网络每秒需要处理超过5000条网络报文。这些报文中的绝大多数,都由ARP和ICMP这样的基础协议承载。在传统IT领域被视为"简单"的协议…...

Marp CLI元数据管理:如何优化SEO和社交媒体分享

Marp CLI元数据管理:如何优化SEO和社交媒体分享 【免费下载链接】marp-cli A CLI interface for Marp and Marpit based converters 项目地址: https://gitcode.com/gh_mirrors/ma/marp-cli Marp CLI是一款强大的命令行工具,让你仅用纯Markdown就…...

广东省高级会计师评审辅导知名品牌

在职业发展的道路上,专业资格认证是许多财务从业者提升自我、拓宽职业路径的重要一环。广东省高级会计师评审,作为一项专业性强、要求严格的职业能力认定,其准备过程需要系统性的指导与支持。中山力朗教育咨询有限公司,作为一家立…...

3步掌握AI模型训练:让新手也能玩转个性化Stable Diffusion模型

3步掌握AI模型训练:让新手也能玩转个性化Stable Diffusion模型 【免费下载链接】sd-trainer 项目地址: https://gitcode.com/gh_mirrors/sd/sd-trainer 在数字创意领域,AI绘画模型训练曾是一道高不可攀的技术门槛。设计师面对复杂的代码配置望而…...

高效智能转换方案:B站缓存视频一键处理实战指南

高效智能转换方案:B站缓存视频一键处理实战指南 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 在B站视频频繁下架的当下&#xff0c…...

Ubuntu系统资源监控实战:从命令行到图形化工具全解析

1. 为什么需要监控Ubuntu系统资源? 刚装好的Ubuntu系统跑得飞快,用着用着突然发现电脑变卡了?浏览器开多几个标签页就开始转圈?这种情况我遇到过太多次了。后来才发现,很多时候是因为某个程序偷偷吃掉了大量CPU或内存资…...

Pi0具身智能v1快速部署指南:一键启动交互测试页面

Pi0具身智能v1快速部署指南:一键启动交互测试页面 1. 环境准备与镜像部署 1.1 选择合适的基础环境 在开始部署Pi0具身智能v1之前,请确保您的平台满足以下基本要求: 硬件配置:建议至少16GB显存的GPU(如NVIDIA RTX 3…...

智能猫砂盆:除臭静音,养猫更省心!

行业痛点分析当前智能猫砂盆领域面临两大核心挑战:清洁残留与安全防护。传统自动铲屎机型在完成集便动作后,猫砂盆底部仍会残留约15%-20%的沾尿结团猫砂(数据表明:第三方实验室对6款主流机型测试结果),用户…...

MediaPipe模型优化:从性能瓶颈到实时推理的全流程解决方案

MediaPipe模型优化:从性能瓶颈到实时推理的全流程解决方案 【免费下载链接】mediapipe Cross-platform, customizable ML solutions for live and streaming media. 项目地址: https://gitcode.com/GitHub_Trending/med/mediapipe 问题发现:计算机…...

CTF逆向实战:从RC4到Base64,手把手拆解CTFshow赛题

1. RC4加密实战:从文件分析到密钥破解 第一次接触CTF逆向题时,看到RC4加密可能会觉得无从下手。但实际拆解后你会发现,这类题目往往藏着明显的突破口。就拿CTFshow这道re2赛题来说,整个解题过程就像在玩解谜游戏。 用IDA打开题目…...

从旅游Vlog到新闻视频:QVHIGHLIGHTS数据集在跨领域应用中的实战指南

QVHIGHLIGHTS数据集:跨领域视频内容智能解析的工程实践 当你在旅行Vlog中搜索"日落时分的海滩漫步",或在新闻视频中寻找"抗议活动现场冲突画面",传统视频平台只能返回整段视频——这就像给你一整本书而不是精确的页码。Q…...

新手福音:通过快马平台生成带详解代码,轻松完成openclaw首次本地部署

今天想和大家分享一个特别适合新手的实践项目——在本地部署openclaw。作为一个刚接触AI部署的小白,我最初看到各种复杂的配置步骤就头大,直到发现了InsCode(快马)平台,整个过程变得简单多了。下面就把我的经验整理成笔记,希望能帮…...

FactoryBluePrints:颠覆性全流程工厂自动化解决方案

FactoryBluePrints:颠覆性全流程工厂自动化解决方案 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints FactoryBluePrints是戴森球计划的开源蓝图仓库,…...

UDOP-large算力优化:FP16推理+FlashAttention加速UDOP-large响应速度

UDOP-large算力优化:FP16推理FlashAttention加速UDOP-large响应速度 1. 为什么你的UDOP-large模型跑得不够快? 如果你用过UDOP-large这个文档理解模型,可能会发现一个问题:处理文档图片的时候,有时候响应速度不够理想…...

资源处理效率工具RePKG:从问题解决到场景创新的实战指南

资源处理效率工具RePKG:从问题解决到场景创新的实战指南 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg 在数字创意和开发工作中,我们经常遇到各种专用格式的…...

Python新手福音:借助快马AI零基础构建你的第一个行情网站

作为一个刚接触Python的新手,想要构建一个行情网站听起来可能有点吓人。但通过InsCode(快马)平台的AI辅助,整个过程变得异常简单。下面我就分享一下自己从零开始搭建第一个行情网站的经历。 数据获取部分 首先需要找到一个免费的金融数据接口。我选择了一…...

Ostrakon-VL-8B打通企业数据流:与内部CRM系统集成实现智能客户分析

Ostrakon-VL-8B打通企业数据流:与内部CRM系统集成实现智能客户分析 你有没有遇到过这样的情况?销售团队抱怨客户画像太模糊,营销活动像在“盲人摸象”,投入了大量资源,转化率却总是不尽如人意。传统的客户关系管理&am…...

开发者的第二曲线:2026年最赚钱的5个技术副业

在技术范式加速重构的2026年,软件质量保障的重要性已从“成本中心”跃升为“价值中心”。对于敏锐的软件测试从业者而言,这不仅是职业的深化,更是将专业壁垒转化为财富增长的绝佳契机。传统的“接私活”模式正在被更具复利效应和杠杆价值的“…...

告别混乱!用PyQt5模块化设计打造你的工业上位机(附完整源码与两种传值方式详解)

工业级PyQt5模块化开发实战:从架构设计到数据交互的完整指南 在工业自动化与测控领域,上位机软件往往需要集成数据采集、实时监控、设备控制等复杂功能。传统开发方式容易导致代码臃肿、维护困难——按钮事件与业务逻辑纠缠不清,数据流向如迷…...

MetaGPT终极指南:5步开启AI驱动软件开发新时代

MetaGPT终极指南:5步开启AI驱动软件开发新时代 【免费下载链接】MetaGPT 🌟 The Multi-Agent Framework: First AI Software Company, Towards Natural Language Programming 项目地址: https://gitcode.com/GitHub_Trending/me/MetaGPT MetaGPT是…...

告别云端依赖:AnythingLLM本地Whisper实现完全离线语音转文字

告别云端依赖:AnythingLLM本地Whisper实现完全离线语音转文字 【免费下载链接】anything-llm The all-in-one AI productivity accelerator. On device and privacy first with no annoying setup or configuration. 项目地址: https://gitcode.com/GitHub_Trendi…...

C++数组和指针的声明与使用指南

数组声明语法 在 C 中声明数组的语法为: 数据类型 数组名[数组大小]; 示例: int myArray[10]; // 声明一个包含 10 个整数的数组 数组初始化 声明时可直接初始化: int myArray[5] {10, 20, 30, 40, 50}; 部分初始化时,未指定值的…...

掌机影音革命:wiliwili跨设备媒体中心实战指南

掌机影音革命:wiliwili跨设备媒体中心实战指南 【免费下载链接】wiliwili 专为手柄控制设计的第三方跨平台B站客户端,目前可以运行在PC全平台、PSVita、PS4 和 Nintendo Switch上 项目地址: https://gitcode.com/GitHub_Trending/wi/wiliwili 在移…...

别再自己造轮子了!用Qt的QModbusTcpClient库5分钟搞定Modbus TCP通讯

别再重复造轮子!用Qt的QModbusTcpClient库5分钟实现工业级Modbus TCP通信 在工业自动化领域,Modbus TCP协议因其简单可靠的特点,已成为PLC与上位机通信的事实标准。许多Qt开发者面对Modbus通信需求时,第一反应往往是手动封装协议栈…...

数据转换的艺术:用DataTransformer优化表单处理

引言 在处理复杂的表单数据时,如何将多个字段的数据有效地转换成一个可存储的字符串是一个常见的问题。在本文中,我们将探讨如何使用Symfony框架中的DataTransformer来解决这个问题,结合一个实际的案例来展示其实现过程。 案例背景 假设我们有一个名为EffectType的自定义…...