Leetcode8-字符串转换整数atoi
目录
Leetcode8-字符串转换整数(atoi)
题目链接:
感觉题目就好难读懂,自己尝试了一下可能是方法太笨就太复杂,并且只能通过一大半的用例。不想折腾了直接copy文心一言代码(deepseek的代码不能完全通过)
int myAtoi(char *str) {
int index = 0;
int sign = 1;
int result = 0;
// Step 1: Skip all leading whitespace characters
// 1. 跳过前导空格
while (isspace(str[index])) {
index++;
}
// Step 2: Check if the next character is '-' or '+'
// 2. 处理符号
if (str[index] == '+' || str[index] == '-') {
sign = (str[index] == '-') ? -1 : 1;
index++;
}
// Step 3: Convert the consecutive digits to an integer
// 3. 读取数字字符
while (isdigit(str[index])) {
int digit = str[index] - '0';
// Step 4: Handle overflow and underflow
// 4. 检查是否溢出
if (result > (INT_MAX - digit) / 10) {
return (sign == 1) ? INT_MAX : INT_MIN;
}
result = result * 10 + digit;
index++;
}
// Apply the sign
// 返回最终结果
return result * sign;
}