[LeetCode][8]【学习日记】实现字符串转换整数 (atoi)函数

题目

8. 字符串转换整数 (atoi)

请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi
函数)。

函数 myAtoi(string s) 的算法如下:

  1. 读入字符串并丢弃无用的前导空格
  2. 检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是正数。 如果两者都不存在,则假定结果为正。
  3. 读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。
  4. 将前面步骤读入的这些数字转换为整数(即,“123” -> 123, “0032” -> 32)。如果没有读入数字,则整数为 0。必要时更改符号(从步骤 2 开始)。
  5. 如果整数数超过 32 位有符号整数范围 [−2^31, 2^31 − 1] ,需要截断这个整数,使其保持在这个范围内。具体来说,小于 −2^31 的整数应该被固定为 −2^31 ,大于 2^31 − 1 的整数应该被固定为 2^31 − 1。
  6. 返回整数作为最终结果。

注意:

  • 本题中的空白字符只包括空格字符 ’ '。
  • 除前导空格或数字后的其余字符串外,请勿忽略任何其他字符。

示例 1:

输入:s = “42” 输出:42 解释:加粗的字符串为已经读入的字符,插入符号是当前读取的字符。
^ 第 1 步:“42”(当前没有读入字符,因为没有前导空格)
^ 第 2 步:“42”(当前没有读入字符,因为这里不存在 ‘-’ 或者 ‘+’)
^ 第 3 步:“42”(读入 “42”)
^ 解析得到整数 42。 由于 “42” 在范围 [−2^31, 2^31 − 1] 内,最终结果为 42。

示例 2:

输入:s = " -42" 输出:-42 解释:
^ 第 1 步:" -42"(读入前导空格,但忽视掉)
^ 第 2 步:" -42"(读入 ‘-’ 字符,所以结果应该是负数)
^ 第 3 步:" -42"(读入 “42”)
^ 解析得到整数 -42。 由于 “-42” 在范围 [−2^31, 2^31 − 1] 内,最终结果为 -42。

示例 3:

输入:s = “4193 with words” 输出:4193 解释:
^ 第 1 步:“4193 with
words”(当前没有读入字符,因为没有前导空格)
^ 第 2 步:“4193 with words”(当前没有读入字符,因为这里不存在 ‘-’ 或者 ‘+’)
^ 第 3 步:“4193 with words”(读入 “4193”;由于下一个字符不是一个数字,所以读入停止)
^ 解析得到整数 4193。 由于 “4193” 在范围 [−2^31, 2^31 − 1] 内,最终结果为 4193。

提示: 0 <= s.length <= 200 s 由英文字母(大写和小写)、数字(0-9)、’ ‘、’+‘、’-’ 和 ‘.’ 组成

思路

图片来自:https://leetcode.cn/leetbook/read/illustration-of-algorithm/lhqzq5/
在这里插入图片描述

  1. 去除前导空格
  2. 判断是否有符号
  3. 对后面的数字进行转 int 的操作,直到添加下一位可能溢出 或 遇到非数字 或 字符串结束

对于第三步的循环解释:

  1. j 小于字符串长度,且 str[j] 应为数字(204851r596)
  2. 以2147483647 / 10 == 214748364 为界。小于这个数则可以添加下一位数;等于这个数则需判断接下来的的一位数加上去是否溢出;大于则因为添加下一位数要先*10,所以必定溢出
    • 小于边界的情况:1234567891,有123456789 < 214748364,此时可以添加下一位数
    • 等于边界的情况:如 2147483648,则 214748364 = = 214748364,而添加8后必定溢出,所以输出溢出时的值;而 214748364 有 214748364 = = 214748364,但是添加 6 后也不溢出
    • 大于边界的情况:如3,000,000,000,3,000,000,00 > 214748364,因为添加下一位数要先*10,所以必定溢出;如20,000,000,000,在 9 位时 200,000,000 < 214748364,此时继续添加下一个 0,然后在下一轮循环中 2,000,000,000 就大于边界,再添加下一个 0 会溢出
  3. 总结:这道题的核心就是在添加下一位后会溢出时,立刻返回溢出值,否则就可以继续添加下一位

简洁解法:

参考 K 神的代码:https://leetcode.cn/leetbook/read/illustration-of-algorithm/lhqzq5/

class Solution {
public:int myAtoi(string str) {int i=0, symbol=1, ans=0;if(!str.length()) return 0;//空字符串while(str[i]==' '){//跳过前导空格++i;}if(str[i]=='-')symbol=-1;//遇到负号if(str[i]=='+' || str[i]=='-')++i;//有符号情况//开始处理数字部分//-2147483648 —— 2147483647for(int j=i; j<str.length() && isdigit(str[j]); ++j){if(ans>214748364 || (ans==214748364&&str[j]>'7')) return (symbol==1 ? INT_MAX : INT_MIN);ans = ans*10 + (str[j]-'0');}return ans*symbol;}
};

繁琐的解法

这种解法之所以繁琐:

  1. 前导空格和符号的处理放在了循环中
  2. 没有找到溢出的边界条件
class Solution {
public:int myAtoi(string str) {int symbol=1, ans=0, numBegin=0, i=0;bool overflow = false, haveFindNum = false;long maxInt = numeric_limits<int>::max();for(i=0; i<str.length(); ++i){if(str[i] == ' ' && !haveFindNum) continue;if(i+1<str.length() && (str[i]=='+' || str[i]=='-') && isdigit(str[i+1]) && !haveFindNum){if(str[i]=='+') symbol = 1;if(str[i]=='-') symbol = -1;numBegin = i+1;continue;}else if(!isdigit(str[i])) break;//下面处理str[i]为数字的情况haveFindNum = true;if(i-1<0) numBegin = 0;else if(i-1>=0 && str[i-1]==' ' && ans) numBegin = i;else if(!ans) numBegin = i;else if(i-2>=0 && str[i-2]=='0' && ans) numBegin = i;if(i-numBegin == 10){cout << numBegin;if(symbol == 1) return ((long)maxInt)*symbol;else return ((long)maxInt+1)*symbol;} long temp;temp = (long)ans * 10;if(temp > maxInt) {cout << "*";if(symbol == 1) return ((long)maxInt)*symbol;else return ((long)maxInt+1)*symbol;} ans *= 10;temp = (long)ans + str[i] - '0';if(temp > maxInt) {cout << "+";if(symbol == 1) return ((long)maxInt)*symbol;else return ((long)maxInt+1)*symbol;}ans += str[i] - '0';}return ans*symbol;}
};

结论

虽然一开始觉得这种题就是找一堆 if 进行判断,不断进行分类而已。但是仔细想想,能快速找到合适的边界条件就可以减少判断的分支个数,这方面能力还需要不断练习来提升。

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

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

相关文章

nginx代理minio客户端

错误方式 在点击桶名查看文件时, 会一直处于loading加载中 worker_processes 1; #设置 Nginx 启动的工作进程数为 1。events {worker_connections 1024; ##设置每个工作进程的最大并发连接数为 1024。 }http {include mime.types; #该文件定义了文件扩展名和 MIME 类型…

WPF中的DataContext

在WPF&#xff08;Windows Presentation Foundation&#xff09;中&#xff0c;DataContext是一个非常关键的概念&#xff0c;它是实现数据绑定的基础。DataContext是所有WPF控件都具有的一个依赖属性&#xff0c;它属于System.Windows.FrameworkElement类&#xff0c;这意味着…

PHP页面重定向

需要注意的是&#xff0c;在调用 header 函数进行重定向之前&#xff0c;确保没有输出任何内容&#xff0c;包括空格、换行符等。这行代码通常用于在处理表单提交或其他逻辑后&#xff0c;将用户引导到另一个页面。 一、指定几秒后进行重定向 例&#xff1a;表示1秒后页面重…

47. 全排列 II(力扣LeetCode)

文章目录 47. 全排列 II题目描述回溯算法 47. 全排列 II 题目描述 给定一个可包含重复数字的序列 nums &#xff0c;按任意顺序 返回所有不重复的全排列。 示例 1&#xff1a; 输入&#xff1a;nums [1,1,2] 输出&#xff1a; [[1,1,2], [1,2,1], [2,1,1]] 示例 2&#xff…

Linux文件描述符剖析

文章目录 文件描述符文件描述符分配规则重定向软硬链接软链接&#xff08;Symbolic Link&#xff09;&#xff1a;硬链接&#xff08;Hard Link&#xff09;&#xff1a; 文件描述符 文件描述符&#xff08;File Descriptor&#xff09;是一个非负整数&#xff0c;用于标识打开…

Java开发从入门到精通(一):Java的基础语法高阶

Java大数据开发和安全开发 &#xff08;一)Java的流程控制1.1 分支语句1.1.1 IF分支语句第一种IF语句第二种IF-ELSE语句第三种IF-ELSE IF-ELSE语句if语句使用的几个常见问题 1.1.2 switch分支语句switch分支的执行流程switch分支的导学案例:电子备忘录if、switch的比较&#xf…

从一个问题开始聊聊clickhouse的物化视图

【问题】 今天有A问我一个问题&#xff0c;我明明创建了一个物化视图&#xff0c;源表是有数据的&#xff0c;为什么查询物化视图就没有数据&#xff1f; 创建物化视图的SQL示意如下&#xff1a; CREATE MATERIALIZED VIEW schema1.test_mvon cluster clusterNameTO schema1…

Spring Mybatis Mapper 模糊查询的几种方法

在Spring结合Mybatis进行开发时&#xff0c;实现模糊查询是一个常见需求。在Mybatis中&#xff0c;LIKE查询可以通过多种方式实现&#xff0c;这取决于你的查询参数如何传递给Mybatis的SQL映射器。以下是实现模糊查询的几种常见方法&#xff1a; 1. 在Mapper接口中直接使用#{}…

【物联网应用案例】从0到N,智慧农业的数据价值

智慧农业全方位渗透到农业的每一个环节&#xff0c;云端解决方案更推动了研究人员、农艺师及农民间的密切协作&#xff0c;为研发企业提供了既经济又具扩展性的完美方案。 据IDC预计&#xff0c;到2036年&#xff0c;农场收集的数据量将增加800%以上&#xff0c;这凸显了农业数…

七.AV Foundation 视频播放 - 图片进度条

引言 播放器的功能功能已经十分完善了&#xff0c;接下来我们给它添加一些提升用户体验的功能。当前市面上的主流播放器几乎都有一个非常友善的功能&#xff0c;用户在退拽进度条的时候可以看见进度条所处进度的视频画面&#xff0c;这对于用户来说是一种直观而且便捷的体验。…

LeetCode刷题---二叉树展开为链表

官方题解&#xff1a;LeetCode官方题解 解题思想&#xff1a; 当根节点不为空时&#xff0c;从二叉树根节点开始遍历 判断当前节点是否有左节点&#xff0c;如果不存在左节点&#xff0c;则当前节点向右移一位 如果存在左节点&#xff0c;创建辅助节点指向左节点&#xff0c;判…

【Python】新手入门(9):数值和序列

&#x1f40d;【Python】新手入门&#xff08;9&#xff09;&#xff1a;数值和序列 &#x1f308; 个人主页&#xff1a;高斯小哥 &#x1f525; 高质量专栏&#xff1a;Matplotlib之旅&#xff1a;零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基础入门教程&am…

百度智能云千帆大模型平台发布会定档3月21日,新模型已悄然上线

百度智能云官微日前宣布&#xff0c;百度智能云千帆产品发布会&#xff08;AI Cloud Day&#xff09;将于2024年3月21日在北京举行&#xff0c;届时将揭晓千帆ModelBuilder 和 AppBuilder 的最新产品进展&#xff0c;并发布系列新模型及开发工具组件。 记者在百度智能云官网上发…

O2O:Offline Meta-Reinforcement Learning with Online Self-Supervision

ICML 2022 paper Introduction 元强化学习(Meta RL)结合O2O。元RL需要学习一个探索策略收集数据&#xff0c;同时还需学习一个策略快速适应新任务。由于策略是在固定的离线数据集上进行元训练的&#xff0c;因此在适应探索策略收集的数据时&#xff0c;它可能表现得不可预测&…

97、我对 AI 模型调优的经验和认识

做 AI 算法调优一些年了,这些年中接触了不少模型,也做过不少在 ASIC 芯片进行模型加速的案例。 在接触的模型中,有一些模型有着非常奇怪的分支结构,有的还有奇怪的 tensor shape,还有的有这奇怪的自定义算法。但在模型优化时,为了将一个 AI 模型性能调到最优,也是无所不…

代码随想录三刷 day16 | 二叉树之104.二叉树的最大深度 559.n叉树的最大深度 111.二叉树的最小深度 222.完全二叉树的节点个数

三刷day16 104.二叉树的最大深度559.n叉树的最大深度111.二叉树的最小深度222.完全二叉树的节点个数 104.二叉树的最大深度 题目链接 解题思路&#xff1a; 本题中根节点的高度就是最大深度 二叉树节点的深度&#xff1a; 指从根节点到该节点的最长简单路径边的条数或者节点数…

飞桨AI框架安装和使用示例

飞桨AI框架安装和使用示例 飞桨PaddlePaddle是非常流行的国产AI框架&#xff0c;让我们一起来动手实践吧&#xff01; 安装 飞桨安装参考页面&#xff1a;https://www.paddlepaddle.org.cn/install/quick?docurl/documentation/docs/zh/install/pip/linux-pip.html 在这个安…

AttributeError: ‘SFTPClient‘ object has no attribute ‘exists‘问题解决

在使用paramiko库进行SFTP操作时&#xff0c;如果遇到AttributeError: SFTPClient object has no attribute exists错误&#xff0c;这意味着你尝试调用的.exists()方法并不直接存在于paramiko.SFTPClient对象中。 虽然SFTPClient类没有内置的.exists()方法&#xff0c;但你可…

【S32K3 MCAL配置】-1.2-GPIO配置及其应用-DIO之高低电平输入-按键(基于MCAL)

"><--返回「Autosar_MCAL高阶配置」专栏主页--> 目录(共11页精讲,基于评估板: NXP S32K312EVB-Q172,手把手教你S32K3从入门到精通) 实现的架构:基于MCAL层 前期准备工作:

垃圾分类网站|基于Springboot框架+java+MYSQL数据库的垃圾分类网站开发设计与实现(可运行源码+数据库+文档)

目录 1.摘 要 2.系统结构设计 3.系统顺序图设计 4.数据库设计 5.系统详细设计 用户前台功能模块 管理员功能模块 垃圾分类管理员功能模块 论文参考 文末获取源码 1.摘 要 本论文主要论述了如何使用JAVA语言开发一个垃圾分类网站 &#xff0c;本系统将严格按照软件开发…