字符串转换函数-leetCode-008

article/2025/8/26 0:40:06

问题描述:

实现一个将字符串转换为整数的函数时,需要考虑各种边界情况和细节,例如空格的处理、符号的判断、数字的读取以及整数溢出的处理等。以下是详细的解题过程以及代码实现。

问题分析

  1. 空格处理:需要丢弃字符串开头的空格字符。

  2. 符号判断:检查字符串的第一个有效字符是否为正或负号。

  3. 数字读取:读取连续的数字字符,直到遇到非数字字符或字符串结束。

  4. 整数溢出处理:确保读取的整数不超过32位有符号整数的范围。

解题思路

  1. 初始化:初始化一个索引用于遍历字符串,以及标志符号的变量。

  2. 跳过前导空格:遍历字符串直到第一个非空格字符。

  3. 判断符号:检查第一个非空格字符是否为正或负号,并设置相应的符号。

  4. 读取数字字符:遍历字符,将连续的数字字符转换为整数,同时检查是否溢出。

  5. 处理溢出:在每一步累加时,检查是否超过32位整数的最大或最小值。

class Solution {public int myAtoi(String s) {int index = 0; // 初始化索引,用于遍历字符串int sign = 1;  // 初始化符号为正int result = 0; // 初始化结果为0int n = s.length(); // 获取字符串长度// 跳过字符串开头的所有空格字符while (index < n && s.charAt(index) == ' ') {index++;}// 检查当前字符是否为正号或负号,以确定整数的符号if (index < n && (s.charAt(index) == '+' || s.charAt(index) == '-')) {sign = (s.charAt(index) == '+') ? 1 : -1; // 根据符号更新sign变量index++; // 移动索引到下一个字符}// 遍历字符串,读取连续的数字字符while (index < n && Character.isDigit(s.charAt(index))) {int digit = s.charAt(index) - '0'; // 将字符转换为对应的数字// 检查是否溢出:如果当前结果大于 (Integer.MAX_VALUE - digit)/10,则下一次乘10加digit会溢出if (result > (Integer.MAX_VALUE - digit) / 10) {// 如果溢出,根据符号返回最大或最小值return (sign == 1) ? Integer.MAX_VALUE : Integer.MIN_VALUE;}// 将当前数字加入结果result = result * 10 + digit;index++; // 移动到下一个字符}// 返回带有符号的结果return sign * result;}
}

时间复杂度

该算法的时间复杂度为 O(n),其中 n 是字符串的长度。这是因为算法中各个步骤的复杂度如下:

  1. 跳过前导空格:最坏情况下,可能需要遍历整个字符串(如果字符串全是空格),时间复杂度为 O(n)。

  2. 处理符号:仅检查一个字符,时间复杂度为 O(1)。

  3. 读取数字字符:最坏情况下,可能需要遍历整个字符串(如果字符串全是数字),时间复杂度为 O(n)。

空间复杂度

该算法的空间复杂度为 O(1),因为只使用了少量的额外变量(如 indexsignresult 等),所使用的额外空间不随输入字符串的长度变化而变化。


http://www.hkcw.cn/article/bXjqOhwnXg.shtml

相关文章

深度学习目标检测实战——YOLOv8从入门到部署

本文将手把手带你用 YOLOv8&#xff08;目前非常先进的目标检测框架&#xff09;实现从数据标注到模型部署的全流程实战&#xff0c;并达到工业级检测精度&#xff01; [yolo视频教程&#xff0c;戳蓝字即可学习] 这才是科研人该学的【YOLO算法全系列】&#xff0c;一口气学完…

C#对象集合去重的一种方式

前言 现在AI越来越强大了&#xff0c;有很多问题其实不需要在去各个网站上查了&#xff0c;直接问AI就好了&#xff0c;但是呢&#xff0c;AI给的代码可能能用&#xff0c;也可能需要调整&#xff0c;但是自己肯定是要会的&#xff0c;所以还是总结一下吧。 问题 如果有一个…

[ctfshow web入门] web124

信息收集 error_reporting(0); //听说你很喜欢数学&#xff0c;不知道你是否爱它胜过爱flag if(!isset($_GET[c])){show_source(__FILE__); }else{//例子 c20-1$content $_GET[c];// 长度不允许超过80个字符if (strlen($content) > 80) {die("太长了不会算");}/…

AI生成思维导图全技术解析

一、AI生成思维导图的底层技术逻辑 (一)知识结构化的核心流程 AI生成思维导图的本质是非结构化文本到结构化知识图谱的转化,其技术流程可拆解为五大核心环节: 1. 语义解析与实体抽取 多模态输入处理:支持文本(Markdown/Word/PDF)、语音(会议录音)、手写笔记(图片O…

秋招Day12 - 计算机网络 - 网络综合

从浏览器地址栏输入URL到显示网页的过程了解吗&#xff1f; 从在浏览器地址栏输入 URL 到显示网页的完整过程&#xff0c;并不是一个单一的数据包从头到尾、一次性地完成七层封装再七层解析的过程。 而是涉及到多次、针对不同目的、与不同服务器进行的、独立的网络通信交互&a…

SpringBoot集成第三方jar的完整指南

原文地址&#xff1a;https://blog.csdn.net/weixin_43826336/article/details/141640152?ops_request_misc%257B%2522request%255Fid%2522%253A%25227d4118ef2d572ba4428caf83f1d2bb28%2522%252C%2522scm%2522%253A%252220140713.130102334…%2522%257D&request_id7d4118…

官宣开源!通过 AI 驱动的前后端 Java Vue 脚手架(AI 后台管理)正式发布!

&#xff08;在本帖评论点赞关注的小伙伴&#xff0c;今日可得好运相随&#xff0c;会有好事发生&#xff0c;不信试试看&#xff5e;&#xff09; &#x1f525; 知路后台管理 - 通过 AI 驱动的新一代前后端脚手架 知路是一个原生集成 AI 并通过 AI 驱动的重新构思、重新设计…

什么是VR全景相机?如何选择VR全景相机?

VR全景相机的定义、原理及特点 定义&#xff1a;VR全景相机是利用特殊镜头设计和图像处理技术&#xff0c;能够捕捉到360度全方位、无死角的高清影像&#xff0c;并通过虚拟现实技术将用户带入沉浸式全景环境的相机设备。 原理&#xff1a;VR全景相机通过集成多个鱼眼镜头&am…

vr中风--数据处理模型搭建与训练2

位置http://localhost:8888/notebooks/Untitled1-Copy1.ipynb # -*- coding: utf-8 -*- """ MUSED-I康复评估系统&#xff08;增强版&#xff09; 包含&#xff1a;多通道sEMG数据增强、混合模型架构、标准化处理 """ import numpy as np impor…

数控技术应用理实一体化平台VR实训系统

::产品概述:: 目前我国本科类院校学生普遍存在的问题就是缺少对实际工作的了解&#xff0c;一直在学习相关专业的理论知识&#xff0c;对社会的相关企业的用人情况不了解。这也就直接导致了毕业的学生和社会上的用人单位需求有点脱节&#xff0c;这也是由于我国的现行本科教育侧…

上传图片转成3D VR效果 / 用photo-sphere-viewer实现图片VR效果

系统简介 : 该系统为 react TS tailwindcss photo-sphere-viewer 的响应式 VR360 项目, 上传图片后可实现手动旋转 3D 图片,还包含了 6 贴图立方体展示和 6 贴图动态展示 目前为单图切换模式 全部页面概览 这是单面VR页面的代码(gif展示页面) import React, { useRef, u…

若依微服务的定制化服务

复制依赖 复制依赖 复制system服务的bootstrap.yml文件&#xff0c;修改port和name 在nacos复制一个新的nacos配置&#xff0c;修改对应的nacos的配置 &#xff0c;可能不需要修改&#xff0c;看情况。 网关修改 注意curd的事项&#xff0c;模块名称的修改

python和风api获取天气(JSON Web Token)

下载安装openssl 默认安装目录&#xff0c;添加C:\Program Files\OpenSSL-Win64\bin到用户Path环境变量 打开cmd&#xff0c;执行命令&#xff0c;会生成两个文件ed25519-private.pem&#xff0c;ed25519-public.pem openssl genpkey -algorithm ED25519 -out ed25519-privat…

【案例分享】蓝牙红外线影音遥控键盘:瑞昱RTL8752CJF

蓝牙红外线影音遥控键盘 Remotec的无线控制键盘采用瑞昱蓝牙RTL8752CJF解决方案&#xff0c;透过蓝牙5.0与手机配对后&#xff0c;连线至 Remotec 红外 code server 取得对应影音视觉设备的红外 code后&#xff0c;即可控制多达2个以上的影音视觉设备&#xff0c;像是智能电视…

Codeforces Round 1025 (Div. 2)

Problem - A - Codeforces 查有没有人说谎&#xff0c;有一个必错的情况&#xff1a; 两个人都说输了&#xff0c;必有人撒谎&#xff0c;还有就是所有人都赢了&#xff0c;也是撒谎 来看代码&#xff1a; #include <iostream> #include <vector> using namespa…

mqtt协议连接阿里云平台

首先现在的阿里云物联网平台已经不在新购了&#xff0c;如下图所示&#xff1a; 解决办法&#xff1a;在咸鱼上租用一个账号&#xff0c;先用起来。 搭建阿里云平台&#xff0c;参考博客&#xff1a; &#xff08;一&#xff09;MQTT连接阿里云物联网平台&#xff08;小白向&…

ubuntu20.04编译 pjproject-2.7.1

一.recompile with -fPIE 分析&#xff1a;需要重新编译并且带上 -fPIE&#xff0c;-fPIE可以使生成的可执行文件在任意内存都可以运行。 解决方法&#xff1a;加上了这两个选项 ./configure CFLAGS"-fPIC -fPIE" CXXFLAGS"-fPIC -fPIE"LDFLAGS"-pi…

HarmonyOS开发:Image使用详解

目录 前言 Image组件基础 1、Image组件概述 2、需要权限 3、Image接口 4、Image组件的基本属性 (1) src (2) width 和 height (3) objectFit (4) alt (5) imageMatrix&#xff08;15&#xff09; (6) sourceSize (7) interpolation 5、Image组件的基本方法&#…

ADC同步采样

目录 1. 同步采样机制的本质区别 2. 关键参数对比 3. 性能与应用场景差异 4. 选型建议 5.总结 AD7609的8路同步采样和AD7616的双路同步采样在架构、性能和应用场景上存在本质区别&#xff0c;主要体现在采样机制、通道同步能力、内部ADC结构以及适用场景等方面。以下是具体…

2.环境搭建

1.安装方式 下载地址&#xff1a;https://neo4j.com/download-center/ 1、Neo4j Enterprise Server&#xff08;企业版&#xff09;2、Neo4j Community Server&#xff08;社区版&#xff09;3、Neo4j Desktop&#xff08;桌面版&#xff09; 2. 安装Neo4j Community Server…