码迷,mamicode.com
首页 > 其他好文 > 详细

剑指Offer——把字符串转换成整数

时间:2017-11-03 00:14:57      阅读:118      评论:0      收藏:0      [点我收藏+]

标签:i++   代码   question   int   res   特殊   return   示例   log   

题目描述:

将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0
 
输入描述:
输入一个字符串,包括数字字母符号,可以为空

输出描述:

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

输入

+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 };

 

剑指Offer——把字符串转换成整数

标签:i++   代码   question   int   res   特殊   return   示例   log   

原文地址:http://www.cnblogs.com/jacen789/p/7747765.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!