题目描述
将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。
输入描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
方法一
从第二个字符开始,判断字符串是否合法。把原字符串中有用的字符挑出来组成一个新的字符串,再转化成整数。
class Solution {
public:
int StrToInt(string str)
{
int len=str.size();
string s="";
for(int i=1;i<len;i++)
{
if(str[i]<'0'||str[i]>'9')
return 0;
}
for(int i=1;i<len;i++)
s=s+str[i];
if(str[0]>='0'&&str[0]<='9')
s=str[0]+s;
else if(str[0]!='+'&&str[0]!='-')
return 0;
int lens=s.size();
if(lens==0)
return 0;
int result=s[0]-'0';
for(int i=1;i<lens;i++)
result=result*10+(s[i]-'0');
if(str[0]=='-')
return -result;
else
return result;
}
};
方法二
通过首位判断符号,设置符号标记,若首位是‘+’或‘-’,变成‘0’,在检验每一位的同时,将其变成整数。
class Solution {
public:
int StrToInt(string str)
{
int len=str.size();
if(len==0)return 0;
int flag=1;
if(str[0]=='+')
str[0]='0';
if(str[0]=='-')
{
str[0]='0';
flag=-1;
}
int sum=0;
for(int i=0;i<len;i++)
{
if(str[i]<'0'||str[i]>'9')
{
sum=0;
break;
}
sum=sum*10+str[i]-'0';
}
return flag*sum;
}
};