题目:
请你来实现一个 atoi 函数,使其能将字符串转换成整数。
首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。
当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。
该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。
注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。
在任何情况下,若函数不能进行有效的转换时,请返回 0。
说明:
假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231, 231 − 1]。如果数值超过这个范围,qing返回 INT_MAX (231 − 1) 或 INT_MIN (−231) 。
思路:
先用char数组保存str,用sign标记是否开始转换,sign = -1表示开始转换,每次循环判断如果开始转换,那么后面只能出现数字,其他的出现直接返回,如果之前已经有数字,比如 4396 sad df 这样的字符串,到空格发现前面已经有转换的数字,返回数字,否则返回0。开始转换的标志是+ - 数字这三个。如果开始将sign置为-1。
转换时要判断是否越界,如果越界返回边界值。
result*symbol > (Integer.MAX_VALUE-(ch[i]-'0'))/10 判断的是超出最大值。这里比较的思想是这样的。
我们要比较 a + b 和 c 的大小 可以转换为比较a 和 b - c 的大小。
主要代码
class Solution {
public int myAtoi(String str) {
char[] ch = str.toCharArray();
int length = ch.length;
int i=0;
int sign= 0;
int symbol = 1;
int result = 0;
while (i<length){
if (ch[i] == '-') {
if (sign != 0)
if (result!=0){
return result*symbol;
}else{
return 0;
}
sign = -1;
symbol = -1;
}else if (ch[i] == '+') {
if (sign != 0)
if (result!=0){
return result*symbol;
}else{
return 0;
}
sign = -1;
symbol = 1;
}else if (ch[i] >= '0' && ch[i] <= '9'){
if (result*symbol > (Integer.MAX_VALUE-(ch[i]-'0'))/10){
return Integer.MAX_VALUE;
}
if (result*symbol < (Integer.MIN_VALUE+(ch[i]-'0'))/10){
return Integer.MIN_VALUE;
}
sign = -1;
result = result*10 + ch[i]-'0';
}else if (ch[i] == ' '){
if (sign == -1){
if (result!=0){
return result*symbol;
}else{
return 0;
}
}else{
}
}else{
break;
}
i++;
}
return result*symbol;
}
}

本文深入解析如何从字符串转换整数的atoi函数实现过程。通过详细步骤讲解,包括处理空格、正负号、数字组合及边界值判断,帮助读者理解并掌握这一核心编程技巧。
437

被折叠的 条评论
为什么被折叠?



