每日算法 -【Swift 算法】字符串转整数算法题详解:myAtoi 实现与正则表达式对比
Swift 字符串转整数算法题详解:myAtoi 实现与正则表达式对比
🧩 题目背景
LeetCode 上的经典算法题 8. String to Integer (atoi) 是一道考察字符串解析与边界处理的题目。这道题虽看似简单,但处理细节相当复杂。我们将使用 Swift 语言实现一个 myAtoi
函数,并分析其实现逻辑,同时引入正则表达式方式作对比,加深理解。
📋 题目要求
实现 myAtoi(_ s: String) -> Int
,将字符串转换为 32 位有符号整数,规则如下:
- 忽略前导空格。
- 处理正负号:若下一个字符是
+
或-
,记录符号。 - 解析数字:从当前位置开始,读取所有连续数字字符。
- 丢弃无效部分:遇到非数字字符即停止。
- 边界截断:如果数字超出 Int32 范围,需截断为
Int32.max
或Int32.min
。 - 返回最终结果。
🛠 原始实现(手动解析法)
func myAtoi(_ s: String) -> Int {let chars = Array(s)var i = 0let n = chars.countvar sign = 1var result = 0// 1. 跳过前导空格while i < n && chars[i] == " " {i += 1}// 2. 处理符号if i < n && (chars[i] == "-" || chars[i] == "+") {sign = chars[i] == "-" ? -1 : 1i += 1}// 3. 解析数字// while i < n && ("0" <= chars[i] && chars[i] <= "9") { 或while i < n, let digit = chars[i].wholeNumberValue {// 溢出检测if result > (Int(Int32.max) - digit) / 10 {return sign == 1 ? Int(Int32.max) : Int(Int32.min)}result = result * 10 + digiti += 1}return result * sign
}
🔍 分步注释说明
chars[i].wholeNumberValue
:安全判断字符是否为数字。- 溢出判断用
(Int32.max - digit) / 10
是防止越界的关键。 - 全过程不依赖标准库的数字转换函数,便于掌控每一步。
⚡ 使用正则表达式实现(更简洁)
func myAtoiWithRegex(_ s: String) -> Int {let pattern = #"^\\s*([+-]?\\d+)"#if let match = s.range(of: pattern, options: .regularExpression) {let numberStr = String(s[match])let num = Int64(numberStr.trimmingCharacters(in: .whitespaces)) ?? 0if num < Int64(Int32.min) {return Int(Int32.min)} else if num > Int64(Int32.max) {return Int(Int32.max)} else {return Int(num)}}return 0
}
✅ 正则说明
^\\s* // 匹配前导空格
[+-]? // 匹配可选符号
\\d+ // 匹配一个或多个数字
正则版本简洁明了,适合快速提取符合格式的数值,但失去对每一步细节的掌控,不能做过细的错误处理和越界防护(比如字符级别的回退分析)。
🤔 小结:手写 vs 正则
方式 | 优点 | 缺点 |
---|---|---|
手动解析法 | 精准控制流程,逐步处理更安全 | 实现稍繁琐 |
正则表达式 | 代码更短,语义清晰 | 灵活性较低,越界控制需额外处理 |
🚀 拓展
- 可以拓展为解析浮点数(
myAtof
)或科学记数法(如1.2e3
) - 借助正则表达式快速实现原型,适合处理用户输入、日志、文本分析
📚 参考
- LeetCode 题解:https://leetcode.com/problems/string-to-integer-atoi/
- Swift 字符处理:https://developer.apple.com/documentation/swift/string
- 正则测试工具:https://regex101.com
👨🏫 下边给出浮点数&科学记数法代码自取
练习题 1:myAtof —— 字符串转浮点数(小数)
func myAtof(_ s: String) -> Double {let pattern = #"^\s*([+-]?((\d+(\.\d*)?)|(\.\d+)))"#let maxDouble = Double.greatestFiniteMagnitudelet minDouble = -Double.greatestFiniteMagnitudeif let match = s.range(of: pattern, options: .regularExpression) {let numberStr = String(s[match]).trimmingCharacters(in: .whitespaces)if let value = Double(numberStr) {if value > maxDouble {return maxDouble} else if value < minDouble {return minDouble} else {return value}}}return 0.0
}/** • ^\s*:匹配开头和任意空格。• [+-]?:可选的正负号。• ((\d+(\.\d*)?)|(\.\d+)):两种小数形式:• 123.456 或 123.(有整数部分,可有小数)• .456(无整数部分,必须有小数)*/
练习题 2:mySciToDouble —— 解析科学计数法字符串
func mySciToDouble(_ s: String) -> Double {let maxDouble = Double.greatestFiniteMagnitudelet minDouble = -Double.greatestFiniteMagnitude// 正则:提取科学计数法格式(e 或 E 可选正负号和数字)let pattern = #"^\s*([+-]?((\d+(\.\d*)?)|(\.\d+))([eE][+-]?\d+)?)"#if let match = s.range(of: pattern, options: .regularExpression) {let numberStr = String(s[match]).trimmingCharacters(in: .whitespaces)if let value = Double(numberStr) {if value > maxDouble {return maxDouble} else if value < minDouble {return minDouble} else {return value}}}return 0.0
}
/** • ^\s*:匹配开头和任意空格。• [+-]?:可选的正负号。• (\d+(\.\d*)?) 整数 + 小数点(如 123.45)• ` (.\d+)`• [eE][+-]?\d+ 可选科学记数法*/
相关文章:
每日算法 -【Swift 算法】字符串转整数算法题详解:myAtoi 实现与正则表达式对比
Swift 字符串转整数算法题详解:myAtoi 实现与正则表达式对比 🧩 题目背景 LeetCode 上的经典算法题 8. String to Integer (atoi) 是一道考察字符串解析与边界处理的题目。这道题虽看似简单,但处理细节相当复杂。我们将使用 Swift 语言实现…...
记录一个难崩的bug
1.后端配置了 Filter 过滤器,如果再配置了Configuration ,那么会出现冲突吗? 过滤器与Configuration类本身无直接冲突,但需注意注册机制、执行顺序和依赖管理。通过显式控制过滤器的注册方式和优先级,结合Spring Security的链式配…...

Git切换历史版本及Gitee云绑定
1、git介绍 Git是目前世界上最先进的分布式版本控制系统 Linux <- BitKeeper(不是开源的,但免费的,后来要收费) Linus Torvalds(林纳斯托瓦兹) 两周时间吧,弄了个 Git;大约一个月就把Linux代码从BitK…...
智能外呼系统中 NLP 意图理解的工作原理与技术实现
智能外呼系统通过整合语音识别(ASR)、自然语言处理(NLP)和语音合成(TTS)等技术,实现了自动化的电话交互。其中,NLP 意图理解是核心模块,负责解析用户话语中的语义和意图&…...

服务器的IP是什么东西?
一、什么是服务器的IP地址? 服务器的IP地址是互联网协议(Internet Protocol)的缩写,是服务器在网络中的唯一数字标识符。它类似于现实生活中的门牌号,用于标识服务器在网络中的位置,使其他设备能够通过它与…...

[问题解决]:Unable to find image ‘containrrr/watchtower:latest‘ locally
一,问题 在使用docker安装部署新应用的时候,报错:Unable to find image containrrr/watchtower:latest locally 分析认为是当前docker的资源库里找不到这个软件的镜像,需要配置一个包含这个软件镜像的新的资源库。 二࿰…...

【文件上传】阿里云对象存储服务实现文件上传
一、基础 上传到本地: package org.example.controller;import lombok.extern.slf4j.Slf4j; import org.example.pojo.Result; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; imp…...

IPv6代理如何引领下一代网络未来
随着互联网技术的不断发展,IPv6逐渐成为下一代网络协议的核心,替代IPv4已是大势所趋。IPv6代理作为IPv6网络环境下的重要工具,为用户提供了更高效、更安全的网络解决方案。 IPv6代理的定义 IPv6代理是在IPv6网络环境中为处理IPv4转换和其他网…...

Linux——数据链路层
1. 认识以太网 认知:以太网是用于局域网数据通信的协议标准,定义了同一局域网内通过电缆/无线怎么在设备之间传输数据帧。 注:整个网络世界可以具象看出由许许多多的局域网组成, • 家庭中的设备A and 家庭中的设备B and 家庭路由…...
ubuntu 22.04 安装下载
ubuntu 22.04下载安装及相关配置_ubuntu22.04下载-CSDN博客...
深度学习面试八股简略速览
在准备深度学习面试时,你可能会感到有些不知所措。毕竟,深度学习是一个庞大且不断发展的领域,涉及众多复杂的技术和概念。但别担心,本文将为你提供一份全面的指南,从基础理论到实际应用,帮助你在面试中脱颖…...
【深度学习-pytorch篇】1. Pytorch矩阵操作与DataSet创建
Pytorch矩阵操作与DataSet创建 1. Python 环境配置 1.1 安装 Anaconda 推荐使用 Anaconda 来管理 Python 环境,访问官网下载安装: https://www.anaconda.com/download/success 1.2 安装 PyTorch 请根据自己的系统平台(Windows/Linux/ma…...

游戏引擎学习第310天:利用网格划分完成排序加速优化
回顾并为今天的内容做个铺垫 昨天我们完成了一个用于排序的空间划分系统,但还没有机会真正利用它。昨天的工作刚好在结束时才完成,所以今天我们打算正式使用这个空间划分来加速排序。 现在我们在渲染代码中,可以看到在代码底部隐藏着一个“…...

数据结构 - 树的遍历
一、二叉树的遍历 对于二叉树,常用的遍历方式包括:先序遍历、中序遍历、后序遍历和层次遍历 。 1、先序遍历(PreOrder) 先序遍历的操作过程如下: 若二叉树为空,则什么也不做;否则࿰…...

时序模型介绍
一.整体介绍 1.单变量 vs 多变量时序数据 单变量就是只根据时间预测,多变量还要考虑用户 2.为什么不能用机器学习预测: a.时间不是影响标签的关键因素 b.时间与标签之间的联系过于弱/过于复杂,因此时序模型依赖于时间与时间的相关性来进行预…...
Java面试实战:从Spring到大数据的全栈挑战
Java面试实战:从Spring到大数据的全栈挑战 在某家知名互联网大厂,严肃的面试官正在面试一位名叫谢飞机的程序员。谢飞机以其搞笑的回答和对Java技术栈的独特见解而闻名。 第一轮:Spring与微服务的探索 面试官:“请你谈谈Spring…...
解决idea与springboot版本问题
遇到以下问题: 1、springboot3.2.0与jdk1.8 提示这个包org.springframework.web.bind.annotation不存在,但是pom已经引入了spring-boot-starter-web 2、Error:Cannot determine path to tools.jar library for 17 (D:/jdk17) 3、Error:(3, 28) java: …...

【第4章 图像与视频】4.4 离屏 canvas
文章目录 前言为什么要使用 offscreenCanvas为什么要使用 OffscreenCanvas如何使用 OffscreenCanvas第一种使用方式第二种使用方式 计算时长超过多长时间适合用Web Worker 前言 在 Canvas 开发中,我们经常需要处理复杂的图形和动画,这些操作可能会影响页…...
[AXI]如何验证AXI5原子操作
如何验证 AXI5 原子操作 摘要:在 UVM (Universal Verification Methodology) 验证环境中,验证 AXI5 协议的原子操作 (Atomic Operations) 是一项重要的任务,特别是在验证支持高并发和数据一致性的 SoC (System on Chip) 设计时。AXI5 引入了原…...

尚硅谷redis7 74-85 redis集群分片之集群是什么
74 redis集群分片之集群是什么 如果主机宕机,那么写操作就被暂时中断,后面就要由哨兵进行投票和选举。那么一瞬间若有大量的数据修改,由于写操作中断就会导致数据流失。 由于数据量过大,单个Master复制集难以承担,因此需要对多个复制集进行…...
Android获取设备信息
使用java: List<TableMessage> dataListnew ArrayList<TableMessage>();//获取设备信息Hashtable<String,String> ht MyDeviceInfo.getDeviceAllInfo2(LoginActivity.this);for (Map.Entry<String, String> entry : ht.entrySet()) {String key entry…...

WPF的基础控件:布局控件(StackPanel DockPanel)
布局控件(StackPanel & DockPanel) 1 StackPanel的Orientation属性2 DockPanel的LastChildFill3 嵌套布局示例4 性能优化建议5 常见问题排查 在WPF开发中,布局控件是构建用户界面的基石。StackPanel和DockPanel作为两种最基础的布局容器&…...

apache的commons-pool2原理与使用详解
Apache Commons Pool2 是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能。 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击…...

打印Yolo预训练模型的所有类别及对应的id
有时候我们可能只需要用yolo模型检测个别类别,并显示,这就需要知道id,以下代码可打印出 from ultralytics import YOLO# 加载模型 model YOLO(yolo11x.pt)# 打印所有类别名称及其对应的ID print(model.names) {0: person, 1: bicycle, 2: c…...
语法糖介绍(C++ Python)
语法糖(Syntactic Sugar)是编程语言中为了提升代码可读性和简洁性而设计的语法结构。它不改变语言的功能,但能让代码更易写和理解。以下是 C 和 Python 中常见的语法糖示例: C 中的常见语法糖 范围 for 循环(Range-bas…...
事务详解及面试常考知识点整理
事务详解及面试常考知识点整理 1. 什么是事务? **事务(Transaction)**是将多条 SQL 语句打包执行的操作单元,具有“一气呵成”的特性。就好比你要完成“把大象放进冰箱”这件事,一共分三步: 打开冰箱门把…...

设计模式26——解释器模式
写文章的初心主要是用来帮助自己快速的回忆这个模式该怎么用,主要是下面的UML图可以起到大作用,在你学习过一遍以后可能会遗忘,忘记了不要紧,只要看一眼UML图就能想起来了。同时也请大家多多指教。 解释器模式(Interp…...

在MDK中自动部署LVGL,在stm32f407ZGT6移植LVGL-8.3,运行demo,显示label
在MDK中自动部署LVGL,在stm32f407ZGT6移植LVGL-8.3 一、硬件平台二、实现功能三、移植步骤1、下载LVGL-8.42、MDK中安装LVGL-8.43、配置RTE4、配置头文件 lv_conf_cmsis.h5、配置lv_port_disp_template 四、添加心跳相关文件1、在STM32CubeMX中配置TIM7的参数2、使能…...

ArcGIS 与 HEC-RAS 协同:流域水文分析与洪水模拟全流程
技术点目录 洪水淹没危险性评价方法及技术介绍基于ArcGIS的水文分析基于HecRAS淹没模拟的洪水危险性评价洪水风险评价综合案例分析应用了解更多 —————————————————————————————————————————————————— 前言综述 洪水危险性及…...
树莓派设置静态ip 永久有效 我的需要设置三个 一个摄像头的 两个设备的
通过 systemd-networkd 配置 此方法适用于较新的Raspberry Pi OS版本,支持同时绑定多个IP地址到同一网卡,且配置清晰稳定。 1.禁用DHCP客户端对eth0的管理:编辑/etc/dhcpcd.conf文件,添加以下内容以忽略eth0接口的自动分配 sudo nano /etc…...