题目描述
将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0
输入描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
示例1
输入
+2147483647
1a33
输出
2147483647
0
思路
数字分正负,先判断首位是什么符号记录下来,后面的字符就存在一个变量里就可以了,上一次结果*10+当前位,最后的结果乘符号位
code
class Solution {
public:
int StrToInt(string str) {
int len=str.length();
if(len==0){
return 0;
}
int res=0;
int flag=1;
for(int i=0;i<len;++i){
if(i==0&&str[i]=='-'){
flag=-1;
continue;
}else if(i==0&&str[i]=='+'){
flag=1;
continue;
}
if('0'<=str[i]&&str[i]<='9'){
res=res*10+str[i]-'0';
}else{
return 0;
}
}
return res*flag;
}
};