【优选算法 | 字符串】字符串模拟题精选:思维+实现解析

在这里插入图片描述

算法相关知识点可以通过点击以下链接进行学习一起加油!
双指针滑动窗口二分查找前缀和位运算
模拟链表哈希表

在众多字符串算法题中,有一类题目看起来没有太多算法技巧,却经常让人“翻车”——那就是字符串模拟题。这类题型往往不依赖复杂的数据结构或高级算法,更多的是对逻辑构造能力、字符串操作细节以及边界处理的考察。本文将通过几个典型字符串模拟题的拆解,帮助你梳理解题思路、掌握通用技巧,从而在这类题目中稳住基本盘。

请添加图片描述

Alt

🌈个人主页:是店小二呀
🌈C/C++专栏:C语言\ C++
🌈初/高阶数据结构专栏: 初阶数据结构\ 高阶数据结构
🌈Linux专栏: Linux
🌈算法专栏:算法
🌈Mysql专栏:Mysql

🌈你可知:无人扶我青云志 我自踏雪至山巅 请添加图片描述

文章目录

    • 14. 最长公共前缀
    • 5. 最长回文子串
    • 67. 二进制求和
    • 43. 字符串相乘

14. 最长公共前缀

题目】:14. 最长公共前缀
在这里插入图片描述

算法思路

解法一:两两比较

在这里插入图片描述

通过两两比较的方式,不断循环寻找字符不相等的位置,利用 substr 接口进行字符串剪切。这里,‘最长公共前缀’的意思是根据木桶效应,取最短字符串的长度作为‘最长公共前缀’的上限。

代码实现

class Solution {
public:string longestCommonPrefix(vector<string>& strs) {//解法一:两两结合string tmp = strs[0];for(int i = 1; i< strs.size(); i++)tmp = findpRrefix(tmp, strs[i]);return tmp;}string findpRrefix(string& s1, string& s2){int i = 0;while(i < min(s1.size(), s2.size()) && s1[i] == s2[i]) i++;return s1.substr(0, i);}
};

解法二:统一比较

在这里插入图片描述

使用 char 类型变量记录字符串中的元素,通过循环逐个比较字符是否相等。考虑到‘最长公共前缀’的上限,当某段完全相同的字符串长度等于当前遍历的字符串长度时,说明已经达到了公共前缀的上限,此时可以直接返回结果。

代码实现

class Solution {
public:string longestCommonPrefix(vector<string>& strs) {//解法二:统计比较for(int j = 0; j < strs[0].size(); j++){char ch = strs[0][j];for(int i = 0; i < strs.size(); i++){if( j == strs[i].size()  || strs[i][j] != ch) return strs[0].substr(0,j);}}return strs[0];}
};

5. 最长回文子串

题目】:5. 最长回文子串

在这里插入图片描述

算法思路

解法:中心扩展算法

  1. 固定一个中心点。
  2. 从中心开始,向两边扩展。

注意:需要同时考虑奇数长度和偶数长度的回文情况。扩展过程中,若遇到越界或不符合回文性质时,停止并返回。中心扩展算法特别适用于回文数的对称特性。

代码实现

class Solution {
public:string longestPalindrome(string s) {//中心扩展算法int begin = 0, len = 0;int n = s.size();for(int i = 0; i < n; i++) //依次枚举所有的中点{int left = i, rigth = i;//奇数扩张while(left >= 0 && rigth < n && s[left] == s[rigth]){left--;rigth++;}if(rigth - left - 1 > len){begin = left + 1;len = rigth - left - 1;}//偶数扩张left = i, rigth = i + 1;while(left >= 0 && rigth < n && s[left] == s[rigth]){left--;rigth++;}if(rigth - left - 1 > len){begin = left + 1;len = rigth - left - 1;}}return s.substr(begin,len);}
};

67. 二进制求和

题目】:67. 二进制求和

在这里插入图片描述

算法思路

解法:高精度模拟加减乘除

高精度算法模拟了列竖式计算过程,通常称为‘二进制高精度加法算法’,对于两个字符串的处理从低位开始。需要特别注意进位处理逻辑,并且要处理前导零的情况。判断条件为:当 cur >= 0 时,继续处理到最前的数据,若不需要加上原数据,默认加0。

数字字符转换为整型时:数字字符 - '0' 即得到整型值。

最后,使用 reverse 进行翻转,以符合题目的要求。

在这里插入图片描述

代码实现

class Solution {
public:string addBinary(string a, string b) {int cur1 = a.size() - 1, cur2 = b.size() - 1;int t = 0;string ret;while(cur1 >= 0 || cur2 >=0 || t ){if(cur1 >= 0)  t += a[cur1--] - '0'; if(cur2 >= 0)  t += b[cur2--] - '0'; ret += t % 2 + '0';t /= 2;}reverse(ret.begin(), ret.end());return ret;}
};

43. 字符串相乘

题目】:43. 字符串相乘

在这里插入图片描述

算法思路

解法一:"模拟"小学的列竖式运算
在这里插入图片描述

解法二:无进位相乘然后相加,最后处理进位

在这里插入图片描述

关于此类高精度题目,推荐先将原始字符串进行反转,因为列竖式计算是从低位开始的。对于两个字符串,先反转它们,再将数字字符转换为整型,通过数组存储结果。我们创建的数组大小为 m + n - 1,其中 mn 分别是两个字符串的长度。通过数学或绘图分析,可以发现这个刚好满足累加所需的存储空间。

这里使用无进位相乘然后相加,最后再处理进位。由于无论是先进行进位还是后进行进位,最终的结果是相同的,因此我们推荐先将结果存储下来,然后再进行进位处理,这样更为方便和简洁,避免了细节很多存在的问题。

算法步骤:

第一步:将输入的两个字符串反转,以便从低位开始进行处理。

第二步:对于两个字符串中的数字,通过下标相加,其两个数字结果正好对应数组中相应位置的值。在进行加法时,需使用 += 来累加结果。

第三步:在处理完所有操作后,可能会出现前导零的情况。最终需要使用 reverse 进行翻转,并去掉多余的前导零。可以通过以下代码来去除前导零:while (ret.size() > 1 && ret.back() == '0') ret.pop_back();

代码实现

class Solution 
{
public:string multiply(string nums1, string nums2) {int n = nums1.size(), m = nums2.size();//字符串反转reverse(nums1.begin(), nums1.end());reverse(nums2.begin(), nums2.end());vector<int> nums(m + n - 1);for(int i = 0; i < n; i++)for(int j = 0; j < m; j++)nums[i + j] += ((nums1[i] - '0') * (nums2[j] - '0')) ;//进位处理string ret;int t = 0, cur = 0;while( cur < m + n -1 || t){if(cur < m + n -1) t += nums[cur++];ret += t % 10 + '0';t /= 10;}//4.处理前导零while(ret.size() > 1 && ret.back() == '0') ret.pop_back();reverse(ret.begin(), ret.end());return ret;}
};

在这里插入图片描述
快和小二一起踏上精彩的算法之旅!关注我,我们将一起破解算法奥秘,探索更多实用且有趣的知识,开启属于你的编程冒险!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/81588.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

虚幻引擎5-Unreal Engine笔记之Default Pawn与GamMode、Camera的关系

虚幻引擎5-Unreal Engine笔记之Default Pawn与GamMode、Camera的关系 code review! 文章目录 虚幻引擎5-Unreal Engine笔记之Default Pawn与GamMode、Camera的关系1.Default Pawn与Camera的关系1.1. Default Pawn 是什么&#xff1f;1.2. Default Pawn 的主要组件1.3. Default…

HarmonyOs开发之———UIAbility进阶

谢谢关注!! 前言:上一篇文章主要介绍开发之———使用HTTP访问网络资源:HarmonyOs开发之———使用HTTP访问网络资源-CSDN博客 代码资源:https://download.csdn.net/download/this_is_bug/90841580 一、基本概念 UIAbility 是 HarmonyOS 应用的核心组件,负责用户界面的…

java实现根据Velocity批量生成pdf并合成zip压缩包

Velocity 模版操作 用的之前写好的: 传送门 其中需要新加一个转成输入流的方法 public static InputStream convertToPdf(StringWriter stringWriter) throws IOException {//将 HTML 转为字节流byte[] htmlBytes stringWriter.toString().getBytes(StandardCharsets.UTF_8)…

SCDN能够运用在物联网加速当中吗?

在当今的科技化时代当中&#xff0c;物联网已经广泛渗透在各个领域行业当中&#xff0c;随着物联网规模的不断扩大&#xff0c;数据信息的传输速度和网络稳定性成为企业需要重视的两点因素&#xff0c;而SCDN也成为安全内容分发网络作为一种融合了内容加速和安全防护的技术&…

二程运输的干散货船路径优化

在二程运输中&#xff0c;干散货船需要将货物从一个港口运输到多个不同的目的地港口。路径优化的目标是在满足货物运输需求、船舶航行限制等条件下&#xff0c;确定船舶的最佳航行路线&#xff0c;以最小化运输成本、运输时间或其他相关的优化目标。 影响因素 港口布局与距离…

Oracle物理恢复相关注意点

如果需要恢复的数据库或者数据文件不存在&#xff0c;则需要将全量备份集RESTORE[ 将全量备份集恢复到目标数据库中&#xff0c;称之为RESTORE。]到目标数据库中&#xff0c;然后再RECOVER[ 将增量备份集或者归档日志恢复到目标数据库中&#xff0c;称之为RECOVER。]增量备份集…

C++ string小记

#include<string> using std::string;string s1; string s2 "hello" //初始化一个hello字符串 string s3(5,a) //连续5个字符a组成的串&#xff0c;即aaaaa///字符串操作int length s1.size() //.size()求字符串长度char c1 s1[1]; //从下标0开始&#xf…

自然语言处理入门级项目——文本分类(预处理)

文章目录 前言1.数据预处理1.1数据集介绍1.2数据集抽取1.3划分数据集1.4数据清洗1.5数据保存 2.样本的向量化表征2.1词汇表2.2向量化2.3自定义数据集2.4备注 结语 前言 本篇博客主要介绍自然语言处理领域中一个项目案例——文本分类&#xff0c;具体而言就是判断评价属于积极还…

C++面试2——C与C++的关系

C与C++的关系及核心区别的解析 一、哲学与编程范式:代码组织的革命 过程式 vs 多范式混合 C语言是过程式编程的典范,以算法流程为中心,强调“怎么做”(How)。例如,实现链表操作需手动管理节点指针和内存。 C++则是多范式语言,支持面向对象(OOP)、泛型编程(模板)、函…

HTTP与HTTPS协议的核心区别

HTTP与HTTPS协议的核心区别 数据传输安全性 HTTP采用明文传输&#xff0c;数据易被窃听或篡改&#xff08;如登录密码、支付信息&#xff09;&#xff0c;而HTTPS通过SSL/TLS协议对传输内容加密&#xff0c;确保数据完整性并防止中间人攻击。例如&#xff0c;HTTPS会生成对称加…

PotPlayer 安装 madVR、LAV Filters 以提升解码能力和视频音频效果

PotPlayer自带的解码器并不是最好&#xff0c;如下两张截图都是出自 TOP GUN: Maverick 较暗、灰蒙蒙的一张&#xff0c;是安装插件之前明亮的一张&#xff0c;是安装插件之后 详细安装参考 https://www.bilibili.com/video/BV1UV5qzuE74?spm_id_from333.788.videopod.sectio…

深入理解 OpenCV 的 DNN 模块:从基础到实践

在计算机视觉领域蓬勃发展的当下&#xff0c;深度学习模型的广泛应用推动着技术的不断革新。OpenCV 作为一款强大且开源的计算机视觉库&#xff0c;其 DNN&#xff08;Deep Neural Network&#xff09;模块为深度学习模型的落地应用提供了高效便捷的解决方案。本文将以理论为核…

Spring MVC 中请求处理流程及核心组件解析

在 Spring MVC 中&#xff0c;请求从客户端发送到服务器后&#xff0c;需要经过一系列组件的处理才能最终到达具体的 Controller 方法。这个过程涉及多个核心组件和复杂的映射机制&#xff0c;下面详细解析其工作流程&#xff1a; 1. 核心组件与请求流程 Spring MVC 的请求处…

RISC-V 开发板 MUSE Pi Pro V2D图像加速器测试,踩坑介绍

视频讲解&#xff1a; RISC-V 开发板 MUSE Pi Pro V2D图像加速器测试&#xff0c;踩坑介绍 今天测试下V2D&#xff0c;这是K1特有的硬件级别的2D图像加速器&#xff0c;参考如下文档&#xff0c;但文档中描述的部分有不少问题&#xff0c;后面会讲下 https://bianbu-linux.spa…

hbase shell的常用命令

一、hbase shell的基础命令 # 版本号查看 [rootTest-Hadoop-NN-01 hbase]$ ./bin/hbase version HBase 2.4.0 Source code repository git://apurtell-ltm.internal.salesforce.com/Users/apurtell/src/hbase revision282ab70012ae843af54a6779543ff20acbcbb629# 客户端登录 […

深入解析Python中的Vector2d类:从基础实现到特殊方法的应用

引言 在Python面向对象编程中&#xff0c;特殊方法&#xff08;或称魔术方法&#xff09;是实现对象丰富行为的关键。本文将以Vector2d类为例&#xff0c;详细讲解如何通过特殊方法为自定义类添加多种表示形式和操作能力。 Vector2d类的基本行为 Vector2d类是一个二维向量类…

Zookeeper入门(三)

Zookeeper Java 客户端 项目构建 ookeeper 官方的客户端没有和服务端代码分离&#xff0c;他们为同一个jar 文件&#xff0c;所以我们直接引入 zookeeper的maven即可&#xff0c; 这里版本请保持与服务端版本一致&#xff0c;不然会有很多兼容性的问题 1 <dependency>…

Redis的主从架构

主从模式 全量同步 首先主从同步过程第一步 会先比较replication id 判断是否是第一次同步假设为第一次同步 那么就会 启动bgsave异步生成RDB 同时fork子进程记录生成期间的新数据发送RDB给从节点 清空本地数据写入RDB 增量同步 对比ReplicationID不同因此选择增量同步在Rep…

新电脑软件配置二:安装python,git, pycharm

安装python 地址 https://www.python.org/downloads/ 不是很懂为什么这么多版本 安装windows64位的 这里我是凭自己感觉装的了 然后cmd输入命令没有生效&#xff0c;先重启下&#xff1f; 重启之后再次验证 环境是成功的 之前是输入的python -version 命令输入错误 安装pyc…

docker 学习记录

docker pull nginx docker 将本地nginx快照保存到当前文件夹下 docker save -o nginx.tar nginx:latestdocker 将本地nginx 加载 docker load -i nginx.tar docker运行nginx在80端口 docker run --name dnginx -p 80:80 -d nginxredis启动 docker run --name mr -p 6379:6379 -…