当前位置: 首页 > wzjs >正文

广州冼村地铁站几号线百度手机助手下载安卓

广州冼村地铁站几号线,百度手机助手下载安卓,郑州微信小程序,政府网站建设标准一、问题描述 在 LeetCode 的算法题库里,有这样一道题目,要求我们实现一个名为 myAtoi(string s) 的函数,其功能是将给定的字符串转换为一个 32 位有符号整数。具体的转换规则如下: 处理步骤 剔除前导空格:读取字符串…

一、问题描述

在 LeetCode 的算法题库里,有这样一道题目,要求我们实现一个名为 myAtoi(string s) 的函数,其功能是将给定的字符串转换为一个 32 位有符号整数。具体的转换规则如下:

处理步骤

  1. 剔除前导空格:读取字符串时,要先把开头无用的空格去除。

  2. 确定符号:查看下一个字符(前提是未到字符串末尾),若为 - 则结果为负,若为 + 则结果为正。若这两个符号都不存在,默认结果为正。

  3. 读取数字:跳过前面的零,开始读取数字,直至遇到非数字字符或者到达字符串末尾。若未读取到任何数字,结果为 0。

  4. 范围截断:如果得到的整数超出了 32 位有符号整数的范围 [−2^31, 2^31 − 1],需要进行截断处理。即小于 −2^31 的整数截断为 −2^31,大于 2^31 − 1 的整数截断为 2^31 − 1

  5. 返回结果:最后将处理好的整数作为最终结果返回。

示例展示

  • 示例 1

    • 输入:s = "42"

    • 输出:42

    • 解释:字符串无前导空格和符号,直接读取到数字 42。

  • 示例 2

    • 输入:s = " -042"

    • 输出:-42

    • 解释:先去除前导空格,再读取到负号,接着读取数字 42(忽略前导零)。

  • 示例 3

    • 输入:s = "1337c0d3"

    • 输出:1337

    • 解释:读取到 1337 后,遇到非数字字符 'c',停止读取。

  • 示例 4

    • 输入:s = "0-1"

    • 输出:0

    • 解释:仅读取到数字 0,遇到 '-' 停止读取。

  • 示例 5

    • 输入:s = "words and 987"

    • 输出:0

    • 解释:第一个字符 'w' 不是数字,直接停止读取。

二、思路分析

为了实现 myAtoi 函数,我们可以按照规则,逐步对输入的字符串进行处理。具体思路如下:

  1. 跳过前导空格:使用一个指针跳过字符串开头的所有空格。

  2. 判断符号:检查指针指向的字符,若为 - 或 +,记录符号并移动指针。

  3. 读取数字:从当前指针位置开始,逐个读取数字字符,将其转换为整数。若遇到非数字字符,停止读取。

  4. 范围判断:在读取数字的过程中,持续检查结果是否超出 32 位有符号整数的范围,若超出则进行截断。

  5. 返回结果:根据记录的符号,给最终结果加上符号并返回。

三、Java 代码实现

public class StringToInteger {public static int myAtoi(String s) {// 去除前导空格s = s.trim();if (s.length() == 0) {return 0;}// 判断符号int sign = 1;int index = 0;if (s.charAt(0) == '-') {sign = -1;index++;} else if (s.charAt(0) == '+') {index++;}// 读取整数int result = 0;while (index < s.length()) {char c = s.charAt(index);if (Character.isDigit(c)) {int digit = c - '0';// 判断是否会溢出if (result > (Integer.MAX_VALUE - digit) / 10) {return sign == 1 ? Integer.MAX_VALUE : Integer.MIN_VALUE;}result = result * 10 + digit;} else {break;}index++;}return sign * result;}public static void main(String[] args) {String s1 = "42";System.out.println(myAtoi(s1)); String s2 = " -042";System.out.println(myAtoi(s2)); String s3 = "1337c0d3";System.out.println(myAtoi(s3)); String s4 = "0-1";System.out.println(myAtoi(s4)); String s5 = "words and 987";System.out.println(myAtoi(s5)); }
}

代码解释

  1. 去除前导空格:使用 trim() 方法去除字符串开头和结尾的空格。若去除空格后字符串为空,直接返回 0。

  2. 判断符号:检查字符串的第一个字符,若为 -,将符号 sign 设为 -1,并将指针 index 后移一位;若为 +,直接将指针 index 后移一位。

  3. 读取整数:从 index 位置开始遍历字符串,若字符为数字,将其转换为整数并累加到 result 中。在累加过程中,需要判断是否会发生溢出。

  4. 范围判断:通过 result > (Integer.MAX_VALUE - digit) / 10 来判断是否会溢出。若会溢出,根据符号返回相应的边界值。

  5. 返回结果:最后将结果乘以符号 sign 并返回。

四、复杂度分析

  • 时间复杂度:(O(n)),其中 n 是字符串的长度。我们只需遍历字符串一次。

  • 空间复杂度:(O(1)),只使用了常数级的额外空间。

感谢各位的阅读,后续将持续给大家讲解力扣中的算法题,如果觉得这篇内容对你有帮助,别忘了点赞和关注,后续还有更多精彩的算法解析与你分享!

http://www.dtcms.com/wzjs/236209.html

相关文章:

  • 新华书店的做的数字阅读网站seo关键词首页排名代发
  • 房地产建设网站的意义seo查询是什么
  • wordpress插件中使用表单郑州seo顾问外包公司
  • 南宁网页制作培训广州:推动优化防控措施落
  • 织梦网站突然打开很慢网站seo优化报告
  • 建网站论坛做网站哪家好
  • 带导航栏的网站seo案例模板
  • 做网站赚多少钱哪里有学电脑培训班
  • 句容本地网站郑州seo优化顾问
  • 注册了域名后怎么设计网站关键词推广技巧
  • 个人建设网站盈利需要什么材料2022双11各大电商平台销售数据
  • 北京装饰公司排行榜宁波seo推广
  • flash网站bannerseo服务顾问
  • 伊宁网站建设推广平台如何做好口碑营销
  • 萍乡企业网站建设windows清理优化大师
  • wordpress分类文章获取seo站群优化
  • JS 微软的翻译接口做网站国际化网络营销包括哪些
  • 照片网站怎么做搜索引擎营销有哪些
  • 网站建设 实训题广告行业怎么找客户
  • 怎么做 代刷网站江西百度推广公司
  • 网站建设预算方案搜索引擎数据库
  • 个人网站要备案么谷歌paypal官网登录入口
  • 湖北平台网站建设哪家好常见的网络直接营销有哪些
  • wordpress切换固定链接404青岛设计优化公司
  • 淘宝上成都网站建设网络营销手段有哪些
  • 建筑公司企业网站网站设计平台
  • 怎么样给一个网站做自然排名怎么优化
  • 很好用的炫酷WordPress主题seo接单平台
  • 虎门微网站建设网站免费制作平台
  • 什么网站做电子相册比加快淘宝关键词排名查询网站