标签:i++ 代码 question int res 特殊 return 示例 log
题目描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
+2147483647 1a33
2147483647 0
分析:
只可能在最开始一位出现符号,所以我们特殊判断第一位,之后都得是数字字母,不然不合法。
代码:
1 class Solution { 2 public: 3 int StrToInt(string str) { 4 int strLen = str.length(); 5 if(strLen == 0) return 0; 6 int res = 0; 7 if(str[0] == ‘+‘ || str[0] == ‘-‘) res = 0; 8 else if(str[0] >= ‘0‘ && str[0] <= ‘9‘) res = str[0] - ‘0‘; 9 for(int i = 1; i < strLen; i++) { 10 if(str[i] < ‘0‘ || str[i] > ‘9‘) return 0; 11 res *= 10; 12 res += str[i] - ‘0‘; 13 } 14 return str[0] == ‘-‘ ? -res : res; 15 } 16 };
标签:i++ 代码 question int res 特殊 return 示例 log
原文地址:http://www.cnblogs.com/jacen789/p/7747765.html