一道经典面试题,atoi函数的实现
参考资料
(2)《剑指offer》
题目分析
本题需要注意的有几个方面:
(1)检查输入参数,指针是否为NULL;
(2)去除字符串前面的空格
(3)处理正负符号
(4)数值部分计算要注意:第一个是处理溢出;第二个是处理字符串中出现非数字符号的情况
(5)整体的错误处理选择:如果函数正确执行,应该返回转换后的数字,所以,就不能使用return某个数字来表示某个错误,而应该定义一个全局的错误变量errno,并在出现不同错误的时候设置该变量。
关于处理溢出的方案:
由于单独处理正负号,所以数值计算的值number不应出现负值,当出现负值的时候说明发生了溢出,这时再根据前面的正负号判断是正溢出还是负溢出,如果是正溢出,则将该值赋为最大正数,在C++中是:std::numeric_limits<int>::max();如果是负溢出,则将该值赋值为最小负数即可。
最后,贴上我的代码,地址是:https://github.com/duqicauc/CodeInterview/blob/master/StrToInt.cpp
#include <iostream>
#include <limits>
using namespace std;
//定义几个错误状态枚举
enum Status{kValid = 0,kNULL,kOVERFLOW,kCHAR};
int status = kValid;
int strToInt(const char* str)
{
/* 空指针检查 */
if (str == NULL)
{
status = kNULL;
return 0;
}
/* 处理字符串前面的几个空格 */
while(isspace(*str))
str++;
/* 正负号处理 */
int flag = 1;
if (*str == '-')
{
flag = -1;
str++;
}
else if (*str == '+')
str++;
/* 数值操作 */
int number = 0;
while(*str != '\0')
{
if (*str >= '0' && *str <= '9')
{
number = number * 10 + *str - '0';
/* 处理overflow,int类型的范围为[-2147483648,2147483647]*/
if (number < 0)
{
if(flag == 1)
number = std::numeric_limits<int>::max();
else if (flag == -1)
number = std::numeric_limits<int>::min();
status = kOVERFLOW;
return number;
}
str++;
}
else
{
/* 处理字符串中的非数字字符,策略是返回无效字符串状态 */
status = kCHAR;
break;
}
}
return number * flag;
}
int main()
{
char str[80];
cout << "请输入字符串:" <<endl;
cin.getline(str,80);
int result = strToInt(str);
switch(status){
case kValid:
cout << "字符串" << str << "对应的整数是:" << result <<endl;
break;
case kNULL:
cout << "空指针错误" <<endl;
break;
case kCHAR:
cout << "输入的字符串中有非数字字符" <<endl;
cout << result <<endl;
break;
case kOVERFLOW:
cout << "输入的字符串对应的数字使得Int类型溢出" <<endl;
cout << result <<endl;
}
return 0;
}
一道经典面试题,atoi函数的实现的更多相关文章
- 一道经典面试题-----setTimeout(function(){},0)
一道经典面试题-----setTimeout(function(){},0) 转载: http://www.w3cfuns.com/notes/17398/e8a1ce8f863e8b5abb5300 ...
- 信雅达面试题atoi函数实现
atoi函数: 功 能: 把字符串转换成整型数. 名字来源:ASCII to integer 的缩写. 原型: int atoi(const char *nptr); 函数说明 参数nptr字符串,如 ...
- 关于fork的一道经典面试题
这是一道面试题,问程序最终输出几个“-”: #include<stdio.h> #include<sys/types.h> #include<unistd.h> i ...
- 经典面试题-python函数之默认参数
1.可变的默认参数----list 示例: def add(a, mylist=[]): # print(id(mylist)) mylist.append(a) return mylist pri ...
- 关于global和$GLOBALS[]的一道经典面试题
在不执行程序的情况下,你觉得的输出结果是什么? <?php $var1 = 1; $var2 = 2; function test(){ global $var1,$var2; $var2 = ...
- 【经典面试题】实现平方根函数sqrt
本文将从一道经典的面试题说起:实现平方根函数,不得调用其它库函数. 函数原型声明例如以下: double Sqrt(double A); 二分法 二分法的概念 求,等价于求方程的非负根(解).求解方程 ...
- 解析js中作用域、闭包——从一道经典的面试题开始
如何理解js中的作用域,闭包,私有变量,this对象概念呢? 就从一道经典的面试题开始吧! 题目:创建10个<a>标签,点击时候弹出相应的序号 先思考一下,再打开看看 //先思考一下你会怎 ...
- 一道经典的js面试题
# 声明:学习编程语言最好的方式就是通过实例学习 ## 下面是我在博客上看到的一道js面试题,可以说非常经典,下面会以最简单的方式让你理解题目:```bashfunction Foo() { getN ...
- OpenJDK源码研究笔记(五)-缓存Integer等类型的频繁使用的数据和对象,大幅度提升性能(一道经典的Java笔试题)
摘要 本文先给出一个看似很简单实则有深意的Java笔试面试题,引出JDK内部的缓存. JDK内部的缓存,主要是为了提高Java程序的性能. 你能答对这道"看似简单,实则有深意"的J ...
随机推荐
- vue form表单上传文件
<script src="https://cdn.staticfile.org/vue-resource/1.5.1/vue-resource.min.js">< ...
- js---省略花括号{}的几种表达式
在进行js的书写中,对于常见的if,for,while是可以简写,省略花括号{}的: var a = 10,b = 20; /** * if 简写 */ if(a > b) console.lo ...
- 荔枝派nano例子
买回来,先短接flash芯片的14脚,然后上电,再断开14脚,开始怎么折腾都不行,最后发现是android线的问题,换成jlink ob送的android线就能找到设备了,真崩溃 lsusb,应该能看 ...
- Java8相关底层
Java8是往并行方向走的.由面向对象到函数式编程. 在支持函数式编程的同时还可以支持面向对象的开发. 在JDK1.8里面,接口里面可以有实现方法的!默认方法,default.实现这个接口. 接口里面 ...
- Katalon studio登陆并进行用户名和密码参数化
前面步骤不截图了,简单说一下: 1.创建空的test case :login 2.点击record录制脚本,走登陆 3.生成的脚本后,点击login用例属性,新建2个变量值 4.创建好后,进入用例页面 ...
- iOS - 判断程序每天只执行一次
当进行操作的时候记录操作时间存在偏好设置当中,当再次点击的时候获取现在的时间然后和之前记录的时间进行比较.如果是一天那么就提示“今天已经操作过了”,如果不是一天,那么可以正常操作,然后记录操作时间.如 ...
- spark sc.textFile() 指定换行符
直接上代码 package com.jason.spark23 import org.apache.spark.sql.SparkSession import org.apache.spark.Spa ...
- PHP设计模式 - 解释器模式
给定一个语言, 定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子. 角色: 环境角色(PlayContent):定义解释规则的全局信息. 抽象解释器(Empress):定 ...
- window 关机
schtasks /create /tn "关机" /tr "shutdown /s" /sc once /st 20:30
- PHP的序列化、对象、反射、异常与错误
1. 怎么理解php里面的序列化与反序列化? 序列化是将对象转换为字节流.反序列化就是将流转换为对象. 这两个过程结合起来,可以轻松地存储和传输数据,在网络中可以做到跨平台.快速传输. 两种序列化方式 ...