热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

字符串转换成整数【微软面试100题第二十题】

题目要求:输入一个表示整数的字符串,把该字符串转换成整数并输出。例如:输入字符串235,输出整数235.参考资料

题目要求:

  输入一个表示整数的字符串,把该字符串转换成整数并输出。

  例如:输入字符串"235",输出整数235.

  参考资料:剑指offer第49题、程序员编程艺术 (by July)

题目分析:

  1.基本思路:

int StrToInt(char *str)
{
int num = 0;while(*str != '\0'){num = num*10+*str-'0';str++;}return num;
}

View Code

 

  2.考虑各种测试用例都能有正确输出:

    • 输入为NULL
    • 输入为非数字
    • 输入为""
    • 输入表示的整数溢出
    • 输入正负数
    • 输入+0/-0

 

代码实现:

剑指offer源码:

 

// 《剑指Offer——名企面试官精讲典型编程题》代码
// 著作权所有者:何海涛
#include
#include
int StrToIntCore(const char* str, bool minus);enum Status {kValid = 0, kInvalid};
//输入为""和"0",都是return 0;则通过全局变量可以进行区分(""是无效的,"0"有效)。
int g_nStatus = kValid;int StrToInt(const char* str)
{g_nStatus
= kInvalid;int num = 0;if(str != NULL && *str != '\0') {bool minus = false;if(*str == '+')str ++;else if(*str == '-') {str ++;minus = true;}//加一个判断可以使得"+"和"-"直接return 0,且全局变量表示无效;if(*str != '\0') {num = StrToIntCore(str, minus);}}return num;
}
int StrToIntCore(const char* digit, bool minus)
{
//用long long避免num溢出long long num &#61; 0;while(*digit !&#61; &#39;\0&#39;) {if(*digit >&#61; &#39;0&#39; && *digit <&#61; &#39;9&#39;) {int flag &#61; minus ? -1 : 1;num &#61; num * 10 &#43; flag * (*digit - &#39;0&#39;);if((!minus && num > 0x7FFFFFFF) || (minus && num <(signed int)0x80000000)){num &#61; 0;break;}digit&#43;&#43;;}else {num &#61; 0;break;}}if(*digit &#61;&#61; &#39;\0&#39;) {g_nStatus &#61; kValid;}return num;
}
// &#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;测试代码&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;&#61;
void Test(char* string)
{
int result &#61; StrToInt(string);if(result &#61;&#61; 0 && g_nStatus &#61;&#61; kInvalid)printf("the input %s is invalid.\n", string);elseprintf("number for %s is: %d.\n", string, result);
}
int main(void)
{Test(NULL);Test(
"");Test("123");Test("&#43;123");Test("-123");Test("1a33");Test("&#43;0");Test("-0");//有效的最大正整数, 0x7FFFFFFFTest("&#43;2147483647"); Test("-2147483647");Test("&#43;2147483648");//有效的最小负整数, 0x80000000Test("-2147483648"); Test("&#43;2147483649");Test("-2147483649");Test("&#43;");Test("-");return 0;
}

View Code

 

转:https://www.cnblogs.com/tractorman/p/4058770.html



推荐阅读
  • 本文详细介绍了 Apache Jena 库中的 Txn.executeWrite 方法,通过多个实际代码示例展示了其在不同场景下的应用,帮助开发者更好地理解和使用该方法。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文探讨了 Objective-C 中的一些重要语法特性,包括 goto 语句、块(block)的使用、访问修饰符以及属性管理等。通过实例代码和详细解释,帮助开发者更好地理解和应用这些特性。 ... [详细]
  • 本文详细介绍了如何在 Spring Boot 应用中通过 @PropertySource 注解读取非默认配置文件,包括配置文件的创建、映射类的设计以及确保 Spring 容器能够正确加载这些配置的方法。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 本文详细介绍了Java中的访问器(getter)和修改器(setter),探讨了它们在保护数据完整性、增强代码可维护性方面的重要作用。通过具体示例,展示了如何正确使用这些方法来控制类属性的访问和更新。 ... [详细]
  • 文件描述符、文件句柄与打开文件之间的关联解析
    本文详细探讨了文件描述符、文件句柄和打开文件之间的关系,通过具体示例解释了它们在操作系统中的作用及其相互影响。 ... [详细]
  • 本文详细介绍了Java中org.w3c.dom.Text类的splitText()方法,通过多个代码示例展示了其实际应用。该方法用于将文本节点在指定位置拆分为两个节点,并保持在文档树中。 ... [详细]
  • 本文探讨了如何优化和正确配置Kafka Streams应用程序以确保准确的状态存储查询。通过调整配置参数和代码逻辑,可以有效解决数据不一致的问题。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 本教程涵盖OpenGL基础操作及直线光栅化技术,包括点的绘制、简单图形绘制、直线绘制以及DDA和中点画线算法。通过逐步实践,帮助读者掌握OpenGL的基本使用方法。 ... [详细]
author-avatar
吻过彩虹的脸_378
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有