【剑指Offer面试编程题】题目1508:把字符串转换成整数--九度OJ
- 题目描述:
-
将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。
- 输入:
-
输入可能包含多个测试样例。
对于每个测试案例,输入为一个合法或者非法的字符串,代表一个整数n(1<= n<=10000000)。
- 输出:
-
对应每个测试案例,
若输入为一个合法的字符串(即代表一个整数),则输出这个整数。
若输入为一个非法的字符串,则输出“My God”。
样例输入:
5 -5 +8样例输出:
5 -5 8【解题思路】本题应该难度不大,首先我们输入一个字符串,然后判断首位,若为符号则需要标记一下,若为数字则加入到结果中,若为其他的证明这个不是合法的字符串不需要往下处理。然后就是后面的字符处理,只需要接纳数字字符,遇到其他字符证明需要停止接纳了。最后输出结果即可。
AC code :
#include <cstdio> using namespace std; int main() { char cc[100]; while(scanf("%s",cc)!=EOF) { bool sig=true,conti=true;; char *c=cc; int re=0; if(*c=='-') sig=false; else if(*c=='+') ; else if(*c>='0' && *c<='9') re=re*10+*c-'0'; else conti=false; if(conti) { ++c; while(*c!='\0') { if(*c>='0' && *c<='9') {re=re*10+*c-'0';++c;} else { conti=false; break; } } } if(!conti) printf("My God\n"); else { if(!sig)re=-re; printf("%d\n",re); } } return 0; } /************************************************************** Problem: 1508 User: huo_yao Language: C++ Result: Accepted Time:0 ms Memory:1020 kb ****************************************************************/
题目链接:http://ac.jobdu.com/problem.php?pid=1508九度-剑指Offer习题全套答案下载:http://download.csdn.net/detail/huoyaotl123/8276299