【数据结构与算法】模拟
成熟不是为了走向复杂,而是为了抵达天真;不是为了变得深沉,而是为了保持清醒。
前言
这是我自己刷算法题的第五篇博客总结。
上一期笔记是关于前缀和算法:
【数据结构与算法】前缀和-CSDN博客
https://blog.csdn.net/hsy1603914691/article/details/147953256?sharetype=blogdetail&sharerId=147953256&sharerefer=PC&sharesource=hsy1603914691&spm=1011.2480.3001.8118
技巧
1. 模拟题思路比较简单,先模拟算法流程,再把流程转换成代码。
2. 模拟题需要特别注意开始和结束,可能需要特殊处理。
3. 模拟题的重点是找规律。
例题
1. leetcode-724题:
1576. 替换所有的问号 - 力扣(LeetCode)
https://leetcode.cn/problems/replace-all-s-to-avoid-consecutive-repeating-characters/description/
class Solution {
public:string modifyString(string s) {int cur=0;while(cur<s.size()){if(s[cur]=='?'){for(char replace='a';replace<='z';replace++){if(cur==0&&replace!=s[cur+1])s[cur]=replace;else if(cur==s.size()-1&&replace!=s[cur-1])s[cur]=replace;else if(cur!=0&&cur!=s.size()-1&&replace!=s[cur+1]&&replace!=s[cur-1])s[cur]=replace;else{}}}cur++;}return s;}
};
2. leetcode-495题:
495. 提莫攻击 - 力扣(LeetCode)
https://leetcode.cn/problems/teemo-attacking/description/
class Solution {
public:int findPoisonedDuration(vector<int>& timeSeries, int duration) {int cur=0,sum=0;while(cur<timeSeries.size()){if((cur!=timeSeries.size()-1&&timeSeries[cur]+duration<=timeSeries[cur+1])||(cur==timeSeries.size()-1)){sum+=duration;cur++;}else{sum+=timeSeries[cur+1]-timeSeries[cur];cur++;}}return sum;}
};
3. leetcode-6题:
6. Z 字形变换 - 力扣(LeetCode)
https://leetcode.cn/problems/zigzag-conversion/
class Solution {
public:string convert(string s, int numRows) {if(numRows==1)return s;string ret;int d=2*numRows-2,n=s.size();for(int i=0;i<n;i+=d)ret+=s[i];for(int k=1;k<numRows-1;k++){for(int i=k,j=d-k;i<n||j<n;i+=d,j+=d){if(i<n)ret+=s[i];if(j<n)ret+=s[j];}}for(int i=numRows-1;i<n;i+=d)ret+=s[i];return ret;}
};
4. leetcode-38题:
38. 外观数列 - 力扣(LeetCode)
https://leetcode.cn/problems/count-and-say/
class Solution {
public:string countAndSay(int n) {string s="1";for(int i=1;i<n;i++){string temp;int left=0,right=0,count=0;while(right<s.size()){while(s[right]==s[left]&&right<s.size())right++;count=right-left;temp.push_back(count+'0');temp.push_back(s[left]);left=right;}s=temp;}return s;}
};
5. leetcode-1419题:
1419. 数青蛙 - 力扣(LeetCode)
https://leetcode.cn/problems/minimum-number-of-frogs-croaking/
class Solution {
public:int minNumberOfFrogs(string croakOfFrogs) {unordered_map<char,int> m;int right=0;while(right<croakOfFrogs.size()){if(croakOfFrogs[right]=='c'){if(m['k']==0)m['c']++;elsem['k']--,m['c']++;}else if(croakOfFrogs[right]=='r'){if(m['c']==0)return -1;elsem['c']--,m['r']++;}else if(croakOfFrogs[right]=='o'){if(m['r']==0)return -1;elsem['r']--, m['o']++;}else if(croakOfFrogs[right]=='a'){if(m['o']==0)return -1;elsem['o']--,m['a']++;}else if(croakOfFrogs[right]=='k'){if(m['a']==0)return -1;elsem['a']--,m['k']++;}elsereturn -1;right++;}if(m['c']==0&&m['r']==0&&m['o']==0&&m['a']==0)return m['k'];elsereturn -1;}
};
致谢
感谢您花时间阅读这篇文章!如果您对本文有任何疑问、建议或是想要分享您的看法,请不要犹豫,在评论区留下您的宝贵意见。每一次互动都是我前进的动力,您的支持是我最大的鼓励。期待与您的交流,让我们共同成长,探索技术世界的无限可能!
相关文章:

【数据结构与算法】模拟
成熟不是为了走向复杂,而是为了抵达天真;不是为了变得深沉,而是为了保持清醒。 前言 这是我自己刷算法题的第五篇博客总结。 上一期笔记是关于前缀和算法: 【数据结构与算法】前缀和-CSDN博客https://blog.csdn.net/hsy1603914691…...

PyTorch入门-torchvision
torchvision torchvision 是 PyTorch 的一个重要扩展库,专门针对计算机视觉任务设计。它提供了丰富的预训练模型、常用数据集、图像变换工具和计算机视觉组件,大大简化了视觉相关深度学习项目的开发流程。 我们可以在Pytorch的官网找到torchvision的文…...
LVS负载均衡群集技术深度解析
第一章 群集技术概述与LVS基础 1.1 群集技术的核心价值与分类 随着互联网应用的复杂化,单台服务器在性能、可靠性、扩展性等方面逐渐成为瓶颈。群集技术(Cluster)通过整合多台服务器资源,以统一入口对外提供服务,成为…...

18、Python字符串全解析:Unicode支持、三种创建方式与长度计算实战
适合人群:零基础自学者 | 编程小白快速入门 阅读时长:约6分钟 文章目录 一、问题:Python的字符串是什么?1、例子1:多语言支持演示2、例子2:字符串不可变性验证3、答案:(1)…...

5月27日复盘-Transformer介绍
5月27日复盘 二、层归一化 层归一化,Layer Normalization。 Layer Normalizatioh和Batch Normalization都是用来规范化中间特征分布,稳定和加速神经网络训练的,但它们在处理方式、应用场景和结构上有本质区别。 1. 核心区别 特征BatchNo…...
CSV数据处理全指南:从基础到实战
CSV(Comma-Separated Values,逗号分隔值) 是一种简单的文件格式,用于存储和交换表格数据(如电子表格或数据库中的记录)。其核心特点是用逗号分隔字段,以换行符分隔记录。 CSV 的定义与结构 基本…...

MyBatis-Plus一站式增强组件MyBatis-Plus-kit(更新2.0版本):零Controller也能生成API?
MyBatis-Plus-Kit 🚀 MyBatis-Plus-Kit 是基于MyBatis-Plus的增强组件,专注于提升开发效率,支持零侵入、即插即用的能力扩展。它聚焦于 免写 Controller、代码一键生成、通用响应封装 等核心场景,让您只需专注业务建模࿰…...

实时数仓flick+clickhouse启动命令
1、启动zookeeper zk.sh start 2、启动DFS,Hadoop集群 start-dfs.sh 3、启动yarn start-yarn.sh 4、启动kafka 启动Kafka集群 bin/kafka-server-start.sh -daemon config/server.properties 查看Kafka topic 列表 bin/kafka-topics.sh --bootstrap-server local…...

【Git】Commit Hash vs Change-Id
文章目录 1、Commit 号2、Change-Id 号3、区别与联系4、实际场景示例5、为什么需要两者?6、总结附录——Gerrit 在 Git 和代码审查工具(如 Gerrit)中,Commit 号(Commit Hash) 和 Change-Id 号 是两个不同的…...
Netty学习专栏(六):深度解析Netty核心参数——从参数配置到生产级优化
文章目录 前言一、核心参数全景解析1.1 基础网络层参数1.2 内存管理参数1.3 水位线控制1.4 高级参数与系统级优化 二、生产级优化策略2.1 高并发场景优化2.2 低延迟场景优化 总结 前言 在分布式系统和高并发场景中,Netty作为高性能网络通信框架的核心地位无可替代。…...
服务器磁盘按阵列划分为哪几类
以下是服务器磁盘阵列(RAID)的详细分类及技术解析,基于现行行业标准与实践应用: 一、主流RAID级别分类 1. RAID 0(条带化) 技术原理:数据分块后并行写入多块磁盘,无…...
在WPF中添加动画背景
在WPF中添加动画背景 在WPF中创建动画背景可以大大增强应用程序的视觉效果。以下是几种实现动画背景的方法: 方法1:使用动画ImageBrush(图片轮播) <Window x:Class"AnimatedBackground.MainWindow"xmlns"htt…...

【KWDB创作者计划】_KWDB分布式多模数据库智能交通应用——高并发时序处理与多模数据融合实践
导读:本文主要探讨了基于KWDB的分布式多模数据库智能交通应用场景,进行了高并发时序处理与多模数据融合实践方向的思考。探索智慧交通领域的数据实时处理与存储资源利用方面的建设思路。 本文目录 一、智能交通数据架构革命 1.1 传统架构瓶颈 …...
Android 中的 ViewModel详解
在 Android 开发中,ViewModel 是 Jetpack 架构组件的核心成员之一,专为管理与界面相关的数据而设计。它通过生命周期感知能力,确保数据在配置变更(如屏幕旋转)时持久存在,并将数据逻辑与 UI 控制器…...

Java集合框架与三层架构实战指南:从基础到企业级应用
一、集合框架深度解析 1. List集合的武林争霸 ArrayList: 数组结构:内存连续,查询效率O(1) 扩容机制:默认扩容1.5倍(源码示例) private void grow(int minCapacity) {int oldCapacity elementData.len…...

6个月Python学习计划 Day 2 - 条件判断、用户输入、格式化输出
6个月Python学习计划:从入门到AI实战(前端开发者进阶指南) Python 基础入门 & 开发环境搭建 🎯 今日目标 学会使用 input() 获取用户输入掌握 if/else/elif 条件判断语法熟悉格式化输出方式:f-string、format() …...
使用docker容器部署Elasticsearch和Kibana
简介:(Elasticsearch) elasticsearch简称Es, 是位于Elastic Stack核心的分布式搜索和分析引擎。它为所有类型的数据提供近乎实时的搜索和分析。无论您拥有机构化或非结构化的文本、数字数据还是地理空间数据,Es都能以支持快速搜索…...
批量处理合并拆分pdf功能 OCR 准确率高 免费开源
各位 PDF 编辑小白们,今天咱来唠唠 PDFXEdit10_Portable 这款软件。 先说说它的核心功能和适用场景。这玩意儿是个便携式的 PDF 编辑工具,不用安装就能直接用,能改 PDF 里的文本、图片,还能批注、调整格式,老方便了。…...
Unity—lua基础语法
Lua 语言执行方式 编译型语言:代码在运行前需要使用编译器,先将程序源代码编译为可执行文件,再执行 C/C Java C# Go Objective-C 解释型语言(脚本语言) 需要提前安装编译语言解析器,运行时使用解析…...

目标检测 TaskAlignedAssigner 原理
文章目录 TaskAlignedAssigner 原理和代码使用示例 TaskAlignedAssigner 原理和代码 原理主要是结合预测的分类分数和边界框与真实标注的信息,找出与真实目标最匹配的锚点,为这些锚点分配对应的目标标签、边界框和分数。 TaskAlignedAssigner 是目标检…...
Qt popup窗口半透明背景
半透明弹窗需要paintEvent()接口支持 方法一:使用setStyleSheet设置半透明样式,如果是子窗口,则可注释构建函数内属性设置 class TranslucentWidget : public QWidget { public: explicit TranslucentWidget(QWidget *parent nullptr)…...

游戏:元梦之星游戏开发代码(谢苏)
《元梦之星》是一款轻松社交派对游戏,玩家们可以化身星宝,体验纯粹的游玩乐趣,收获简单的快乐。无论i人e人,都能轻松找到属于自己的社交方式。 《元梦之星》的快乐,可以是闯关夺冠时的激动,谁是狼人推理的巧妙,峡谷3V3打赢团战的爽感。也可以是星梦广场开…...

TCP协议原理与Java编程实战:从连接建立到断开的完整解析
1.TCP协议核心:面向连接的可靠通信基石 TCP(Transmission Control Protocol,传输控制协议)是互联网的“可靠信使”,属于传输层协议,其核心在于面向连接和可靠传输。它通过严谨的握手机制与数据控制逻辑&am…...
Linux的top命令使用
Linux系统中top命令详解及使用技巧 一、基础功能 top命令用于实时监控系统性能和进程活动,可查看以下信息: - CPU使用率 - 内存使用情况 - 进程状态信息 - 系统负载数据 二、使用步骤 1. 打开终端输入命令:top 2. 查看实时更新的数据界面&a…...
Spring Cloud Gateway 限流实践:基于 Redis 令牌桶算法的网关层流量治理
一、引言 在微服务架构中,API 网关作为流量枢纽,需对进入系统的请求进行精细化限流,以保护下游服务免受流量冲击。Spring Cloud Gateway 结合 Redis 实现的令牌桶算法,为网关层限流提供了高效、分布式的解决方案。本文将深入解析其原理、配置及实践优化。 二、技术栈与原…...
可视化大屏实现全屏或非全屏
通过点击按钮实现全屏和非全屏效果展示 代码如下: <template> //点击icon图片进入全屏或非全屏<img :src"screenStatus ? /src/assets/noFull.png : /src/assets/full.png" alt"" click"enterFullScreen" /> </te…...
java8函数式接口(函数式接口的匿名实现类作为某些方法的入参)
文章目录 前置介绍通过 lambda 表达式,使用匿名类,实现函数式接口函数式接口和回调函数的关系函数式接口的应用 前置介绍 是 Java 8 引入的核心概念之一,指的是 仅包含一个抽象方法的接口。它可以被 FunctionalInterface 注解标记࿰…...
linux自有服务
文章目录 [TOC](文章目录)linux自有服务概述systemctl管理服务命令CentOS 7 之前CentOS 7 常用自有服务ntpd或systemd-timesyncd时间同步服务ntp同步服务器原理ntpd时间同步操作systemd-timesyncd同步原理systemd-timesyncd时间同步操作 firewalld防火墙计划任务crontab CentOS…...
UniApp网页版集成海康视频播放器
注意:本人全部集成好后使用最新的海康平台下载插件进行替换后就不能预览视频 使用Uni插件进行集成:海康视频H5播放器组件 - DCloud 插件市场 CSDN资源下载:https://download.csdn.net/download/wangdaoyin2010/90910975 注意:初…...
Filter和Interceptor详解(一文了解执行阶段及其流程)
Filter和Interceptor的区别 Filter(过滤器)和 Interceptor(拦截器)都是用于在请求处理前后插入额外逻辑的组件,下面依次介绍,并额外介绍Spring Gateway的过滤器(GlobalFilter/GatewayFilter&am…...