剑指49-把字符串转换成整数

题目描述

将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。

输入描述:

输入一个字符串,包括数字字母符号,可以为空

输出描述:

如果是合法的数值表达则返回该数字,否则返回0

示例1

1
2
3
4
5
6
输入
+2147483647
1a33
输出
2147483647
0

其实题目的返回值设定有问题,返回0时无法推断出其输入是合法的0,还是非法表达。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
class Solution:
def StrToInt(self, s):
digits = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9']
pres = ['+', '-']

val = 0
sign = None
for i in range(len(s)):
if i == 0:
if s[i] in pres:
sign = s[i]
continue
if s[i] not in digits:
return 0
val *= 10
val += int(s[i])
if sign == '-':
val = 0-val
return val