Leetcode: String to Integer (atoi)
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode: String to Integer (atoi)相关的知识,希望对你有一定的参考价值。
class Solution { public: int myAtoi(string str) { if (str == "") return 0; //判断是否为空 int i = 0, sign = 1; long long sum = 0; //用long long来存结果,易于判断是否溢出,用int的话比较麻烦 while (str[i] == ‘ ‘) i++; //忽略前置的空格 //判断是否溢出,溢出的话根据sign判断返回最小值还是最大值,这里体现了用longlong的好处 if (str[i] == ‘+‘ || str[i] == ‘-‘) sign = 44 - str[i++]; for (i; i < str.length(); i++) { if (str[i] >= ‘0‘ && str[i] <= ‘9‘) sum = sum * 10 + str[i] - ‘0‘; else break; //判断是否溢出,溢出的话根据sign判断返回最小值还是最大值,这里体现了用longlong的好处 if (sum > INT_MAX) return sign == -1 ? INT_MIN : INT_MAX; } return sum * sign; } };
以上是关于Leetcode: String to Integer (atoi)的主要内容,如果未能解决你的问题,请参考以下文章
[Leetcode] String to Integer (atoi)
LeetCode 1055. Shortest Way to Form String
Leetcode: String to Integer (atoi)