题目描述
将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。
输入描述:
输入一个字符串,包括数字字母符号,可以为空
输出描述:
如果是合法的数值表达则返回该数字,否则返回0
分析:注意以下几方面(1)+-号处理(2)前面空格的处理(3)越界处理(4)最后while循环出去的return
int StrToInt(string str) {
//数值为0,或者不是合法的字符串返回0
int len=str.size();
if(len<=0)
return 0;
int flag=1;//默认正数
int i=0;
while(str[i]!='\0')
{
//正负号处理
if(str[i]=='+')
{
i++;
}
else if(str[i]=='-')
{
i++;
flag=-1;
}
//空格处理
while(str[i]==' ')
{
i++;
}
//正式开始
int sum=0;
while(isdigit(str[i]))
{
sum=sum*10+str[i]-'0';
i++;
//越界处理
if(sum>INT_MAX)
return INT_MAX;
if(sum<INT_MIN)
return INT_MIN;
}
//来到这说明没有数字了,如果结束了就说明合法,直接返回数值
if(str[i]=='\0')
return flag*sum;
else
return 0;
}
//能来到这,说明不合法
return 0;
}