力扣 - 剑指 Offer 67. 把字符串转换成整数
题目
思路1
- 根据题意,要解决这题,首先要判断的条件有:
- 不包括首位空格
- 第一位必须为:
+、-、数字三者其一,否则不合法 - 数字必须连续的,如果遇到非数字,结束判断
- 判断结果要在 \(-2^{31}\)~\((2^{31}-1)\) 之间,如果超过的话,就输出最大值 / 最小值
- 我们用sign记录符号、res记录每次遍历累加的值、threshold记录阈值(我们阈值取
Integer.MAX_VALUE/10,即小了一位数,作用后面再说)、index记录开始的索引。接下来开始解析:- 首先,我们使用Java的
trim方法去除首位空格 - 然后判断第一位的字符是什么,为负号
sign就为-1,默认是正号1。同时还要设置开始比遍历的索引index,如果为负号或者显示的正号,我们就设置为1(因为这两个符号都占了一个位置),否则就默认从0开始(这时候不用管是否为数字,这个判断留到下面再去判断) - 接下来根据前面设置的index,从index开始遍历字符串,判断每一位字符:
- 如果不为数字则跳出循环;
- 如果
res结果大于阈值(res还没加上当前值,因为如果res已经大于阈值了,不管当前值是多大也没有影响)则说明拼接后的值已经超过了Integer.MAX_VALUE,需要返回整数的最大值; - 如果
res == threshold,且当前的值也大于7(为什么要大于7呢,因为大于7就说明大于正整数的最大值,前几位一样,那么就比较最后一位嘛),此时再根据符号,直接返回最大值即可。 - (注意:因为最大正整数和最小负整数不仅仅是符号不一样的区别,将最小负整数去掉符号之后,还是比最大正整数的值还大1。所以这个是如何保证能正确判断呢?主要是在
cs[i] > '7'这个地方:这个条件判断了如果res等于最大正整数,此时不是直接返回最大正整数,而是进行拼接,进行下一轮判断,当然,如果是负数的话,达到-2147483647也是进行拼接,如果是-2147483648,那么就会直接返回最大负整数,这也就是为什么c[i]要大于7而不是大于等于‘7了)
- 如果上一步都没超最大值,此时讲当前值拼接到res中即可:
res = res*10 + (cs[i] - '0'); - 最后返回
res*sign,由sign控制符号
- 首先,我们使用Java的
代码
class Solution {
public int strToInt(String str) {
char[] cs = str.trim().toCharArray();
// 非空格的字符长度为0,直接返回0
if (cs.length == 0) {
return 0;
}
// 符号标志,代表正负号,默认为正
int sign = 1;
// 存储结果
int res = 0;
// 默认第一位是符号,所以从第二位开始计算,即1
int index = 1;
// 阈值
int threshold = Integer.MAX_VALUE / 10;
// 判断第一位非空格的的字符
if (cs[0] == '-') {
// 负号
sign = -1;
} else if (cs[0] != '+') {
// 如果不是正号的话,我们先默认:第一位是数字、为正数,下面再进行判断
index = 0;
}
// 根据前面的index判断是从第0位还是第1位开始判断
for (int i = index; i < cs.length; i++) {
// 不是数字就直接结束
if (cs[i] < '0' || cs[i] > '9') {
break;
}
// 超出范围
if (res > threshold || (res == threshold && cs[i] > '7')) {
return sign == 1 ? Integer.MAX_VALUE : Integer.MIN_VALUE;
}
// 进行拼接
res = res*10 + (cs[i] - '0');
}
return sign * res;
}
}
复杂度分析
- 时间复杂度:\(O(N)\),线性遍历数组所需时间为\(O(N)\)
- 空间复杂度:\(O(N)\),将字符串转换成字符数组所占用的空间
力扣 - 剑指 Offer 67. 把字符串转换成整数的更多相关文章
- 剑指 Offer 67. 把字符串转换成整数 + 字符串
剑指 Offer 67. 把字符串转换成整数 Offer_67 题目描述 题解分析 java代码 package com.walegarrett.offer; /** * @Author WaleGa ...
- 【Java】 剑指offer(67) 把字符串转换成整数
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 请你写一个函数StrToInt,实现把字符串转换成整数这个功能 ...
- Go语言实现:【剑指offer】把字符串转换成整数
该题目来源于牛客网<剑指offer>专题. 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 输入描述: 输入一个字符串,包括数字字母符号,可以为空. 输出描述: 如果是合 ...
- 剑指Offer 49. 把字符串转换成整数 (字符串)
题目描述 将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一 ...
- [剑指Offer] 49.把字符串转换成整数
题目描述 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 数值为0或者字符串不是一个合法的数值则返回0 [思路]考虑所有特殊情况 1.数字前面有空格,如s=" 12 ...
- 力扣 - 剑指 Offer 46. 把数字翻译成字符串
题目 剑指 Offer 46. 把数字翻译成字符串 思路1(递归,自顶向下) 这题和青蛙跳台阶很类似,青蛙跳台阶说的是青蛙每次可以跳一层或者两层,跳到第 n 层有多少种解法,而这题说的是讲数字翻译成字 ...
- 剑指offer49:把字符串转换成整数
1 题目描述 将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数. 数值为0或者字符串不 ...
- 《剑指offer》面试题67. 把字符串转换成整数
问题描述 写一个函数 StrToInt,实现把字符串转换成整数这个功能.不能使用 atoi 或者其他类似的库函数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. ...
- [LeetCode]面试题67. 把字符串转换成整数
题目 写一个函数 StrToInt,实现把字符串转换成整数这个功能.不能使用 atoi 或者其他类似的库函数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我们 ...
随机推荐
- Shell系列(17)- 配置文件功能(待完善)
配置文件功能 文件名 功能 相关联命令 /etc/profile USER变量 LOGNAME变量 MAIL变量 PATH变量 HOSTNAME变量 umask 调用/etc/profile.d/*. ...
- springboot pom.xml
Demo project for Spring Boot <?xml version="1.0" encoding="UTF-8"?> <pr ...
- JMeter主要元件
配置元件 http cookie管理器 http信息头管理器 http请求默认值 统一管理 快速切换测试环境 http cache管理器 静态资源 监听器元件 查看结果树 分析查看某个请求的详情 请求 ...
- jmeter旅程第一站:Jmeter抓包浏览器或者抓取手机app的包
学习jmeter?从实际出发,我也是一个初学者,会优先考虑先用来做一些简单的抓包.接口测试,在实践的过程中学习jmeter用途.那么接下来,这篇文章我会以jmeter抓包开启我的jmeter旅程. 这 ...
- hdu5909-Tree Cutting【FWT】
正题 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5909 题目大意 给出\(n\)和\(m\)(\(m=2^k\)).再给出一个大小为\(n\)的树 ...
- Linkerd stable-2.11.0 稳定版发布:授权策略、gRPC 重试、性能改进等!
公众号:黑客下午茶 授权策略 Linkerd 的新服务器授权策略(server authorization policy)功能使您可以细粒度控制允许哪些服务相互通信.这些策略直接建立在 Linkerd ...
- windows下将Anaconda移位置(C盘转移至D盘)
1.首先说明一下我的安装情况: (1)Window10系统 (2)Anaconda安装在C盘 2.由于Anaconda安装在C盘经常会涉及权限问题,在安装torch的时候让我萌发了转移磁盘的想法(拒绝 ...
- JS返回一个字符串中长度最小的单词的长度
题目:编写一个方法,返回字符串中最小长度的单词的长度. var str = 'What a good day today!'; 1 //方法一 2 function returnString1(str ...
- mysql通过logstash同步数据到es
大小写问题很严重 input 1.statement:mysql的连接使用 jdk版本有强要求 2.jdbc_driver_library:jar包的版本有对应要求 3.jdbc_driver_cla ...
- 都 2021 年了,Serverless 能取代微服务吗?
来源 | Serverless 公众号 编译 | OrangeJ 作者 | Mariliis Retter "Serverless 能取代微服务吗?" 这是知乎上 Serverle ...