【字符串处理算法】字符串转换为整数的算法设计及C代码实现

开发 开发工具 算法
今天讲一讲字符串转换为整数的算法设计及C代码实现。

一、需求描述

输入一个由数字构成的字符串,编写程序将该字符串转换为整数并输出。

例如,如果输入的字符串是“12345”,那么输出的整数是12345。注意,不要使用C语言的库函数atoi。

[[180304]]

二、算法设计

我们都知道,如果给定一个整数123,那么其表示方法是:123=1*100+2*10+3。也就是说,一个整数是由其各位上的数字按照位数求和组成的。

因此,这个需求的解决方法很简单,只要将字符串中的各位数字按照其位数相加就行了。在此过程中,要考虑一些特殊情况。

程序的总体流程如图1所示。

图1 程序的总体流程

三、特殊流程考虑

在编写程序的过程中,我们要对输入的数字串的长度及格式多做考虑,如:

1.如果输入的字符串中包含了除数字之外的其它字符,那么程序直接返回,不进行后续处理。

2.如果数字串是以一个或多个字符0开头的,则要先将其去掉之后再进行后续处理。

3.因为在C语言中,整型(int)所能表示的***数为2147483647,所以如果输入的数字串大于了“2147483647”,那么程序直接返回,不进行后续处理。

四、程序代码

  1. /********************************************************************** 
  2. * 版权所有 (C)2016, Zhou Zhaoxiong。 
  3. * 文件名称: StrToInt.c 
  4. * 文件标识: 无 
  5. * 内容摘要: 将字符串转换为整数 
  6. * 其它说明: 例如, 将"123"转换为123 
  7. * 当前版本: V1.0 
  8. * 作    者: Zhou Zhaoxiong 
  9. * 完成日期: 20160218 
  10. **********************************************************************/ 
  11. #include <stdio.h> 
  12. #include <limits.h>   // 由于在代码中使用了INT_MAX, 因此要包含该头文件 
  13.  
  14.  
  15. // 重新定义数据类型 
  16. typedef signed   char  INT8; 
  17. typedef          int   INT32; 
  18. typedef unsigned int   UINT32; 
  19.  
  20.  
  21. // 函数声明 
  22. INT32 CalIntVal(INT32 iBitLen); 
  23. INT32 JudgeIfOverFlow(INT8 *pszTestStr); 
  24.  
  25.  
  26. /********************************************************************** 
  27. * 功能描述: 主函数 
  28. * 输入参数: 无 
  29. * 输出参数: 无 
  30. * 返 回 值: 0-执行成功   其它-执行失败 
  31. * 其它说明: 无 
  32. * 修改日期        版本号     修改人            修改内容 
  33. * --------------------------------------------------------------------- 
  34. * 20160218        V1.0     Zhou Zhaoxiong        创建 
  35. ***********************************************************************/ 
  36. INT32 main() 
  37.     INT8   szInputStr[100] = {0}; 
  38.     INT8   szTestStr[100]  = {0}; 
  39.     INT32  iResultInt      = 0;    // 转换之后的整数***支持2147483647 
  40.     UINT32 iPosFlag        = 0
  41.     UINT32 iTestStrLen     = 0
  42.     UINT32 iBitVal         = 0
  43.     INT32  iRetVal         = 0
  44.  
  45.     printf("Max value of int is %d\n", INT_MAX);   // 求出int的***值 
  46.      
  47.     printf("Please input the string: \n"); 
  48.     scanf("%s", szInputStr); 
  49.     printf("InputStr=%s\n", szInputStr); 
  50.  
  51.     // 判断输入的字符串中是否有除数字之外的其它字符, 若有, 则直接退出 
  52.     for (iPosFlag = 0; iPosFlag < strlen(szInputStr); iPosFlag ++) 
  53.     { 
  54.         if (szInputStr[iPosFlag] < '0' || szInputStr[iPosFlag] > '9') 
  55.         { 
  56.             printf("%s is not a digital string, please check!\n", szInputStr); 
  57.             return -1; 
  58.         } 
  59.     } 
  60.  
  61.     // 如果字符串前面有字符0, 则将其去掉 
  62.     iPosFlag = 0
  63.     while (szInputStr[iPosFlag] == '0') 
  64.     { 
  65.         iPosFlag ++; 
  66.     } 
  67.  
  68.     // 获取去除0之后的字符串值 
  69.     strncpy(szTestStr, szInputStr+iPosFlag, strlen(szInputStr)-iPosFlag); 
  70.  
  71.     // 判断字符串是否大于2147483647, 若是, 则直接退出 
  72.     iRetVal = JudgeIfOverFlow(szTestStr); 
  73.     if (iRetVal != 0) 
  74.     { 
  75.         printf("%s is bigger than INT_MAX(2147483647), please check!\n", szTestStr); 
  76.         return -1; 
  77.     } 
  78.      
  79.     // 计算字符串对应的整数值 
  80.     iTestStrLen = strlen(szTestStr); 
  81.     iResultInt = 0
  82.     for (iPosFlag = 0; iPosFlag < iTestStrLen; iPosFlag ++) 
  83.     { 
  84.         iBitVal = szTestStr[iPosFlag] - '0';    // 计算每一位对应的数字 
  85.         iResultIntiResultInt = iResultInt + iBitVal * CalIntVal(iTestStrLen-iPosFlag); 
  86.     } 
  87.  
  88.     printf("ResultInt=%d\n", iResultInt); 
  89.      
  90.     return 0;             
  91.  
  92.  
  93. /********************************************************************** 
  94. * 功能描述: 判断输入的字符串是否溢出 
  95. * 输入参数: pszTestStr-测试字符串 
  96. * 输出参数: 无 
  97. * 返 回 值: 1-溢出  0-未溢出 
  98. * 其它说明: 判断字符串是否大于2147483647, 若是, 则溢出 
  99. * 修改日期          版本号         修改人          修改内容 
  100. * --------------------------------------------------------------- 
  101. * 20160218          V1.0       Zhou Zhaoxiong        创建 
  102. ***********************************************************************/ 
  103. INT32 JudgeIfOverFlow(INT8 *pszTestStr) 
  104.     UINT32 iTestStrLen         = 0
  105.     INT8   szProcessedStr[100] = {0}; 
  106.     INT8   szMaxValOfInt[100]  = {0}; 
  107.  
  108.     snprintf(szMaxValOfInt, sizeof(szMaxValOfInt)-1, "%d", INT_MAX);   // 求出int的***值 
  109.  
  110.     iTestStrLen = strlen(pszTestStr); 
  111.  
  112.     if (iTestStrLen > strlen(szMaxValOfInt))         // 长度超过 
  113.     { 
  114.         return 1; 
  115.     } 
  116.     else if (iTestStrLen == strlen(szMaxValOfInt))   // 长度相等 
  117.     { 
  118.         if (strcmp(pszTestStr, szMaxValOfInt) > 0)   // 溢出 
  119.         { 
  120.             return 1; 
  121.         } 
  122.         else 
  123.         { 
  124.             return 0; 
  125.         } 
  126.     } 
  127.     else     // 测试字符串长度小于"2147483647"的长度, 未溢出 
  128.     { 
  129.         return 0; 
  130.     } 
  131.  
  132.  
  133.  
  134. /********************************************************************** 
  135. * 功能描述: 求字符串中的每一位所对应的整数值 
  136. * 输入参数: iBitLen-对应整数的第多少位 
  137. * 输出参数: 无 
  138. * 返 回 值: 该位所对应的整数值 
  139. * 其它说明: 无 
  140. * 修改日期          版本号         修改人          修改内容 
  141. * --------------------------------------------------------------- 
  142. * 20160218          V1.0       Zhou Zhaoxiong        创建 
  143. ***********************************************************************/ 
  144. INT32 CalIntVal(INT32 iBitLen) 
  145. {     
  146.     if (iBitLen == 1)   // 个位 
  147.     { 
  148.         return 1; 
  149.     } 
  150.     else 
  151.     { 
  152.         return 10 * CalIntVal(iBitLen-1); 
  153.     } 

五、程序测试

我们将编写好的程序“StrToInt.c”上传到Linux机器,并使用“gcc -g -o StrToIntStrToInt.c”命令对该程序进行编译,生成“StrToInt”文件。下面对程序进行详细的测试。

1.输入字符串为“12345”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. 12345 
  4. InputStr=12345 
  5. ResultInt=12345 

2.输入字符串为“-12345”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. -12345 
  4. InputStr=-12345 
  5. -12345 is not a digital string, please check! 

3.输入字符串为“123456a”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. 123456a 
  4. InputStr=123456a 
  5. 123456a is not a digital string, please check! 

4.输入字符串为“012345”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. 012345 
  4. InputStr=012345 
  5. ResultInt=12345 

5.输入字符串为“0123450”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. 0123450 
  4. InputStr=0123450 
  5. ResultInt=123450 

6.输入字符串为“2147483647”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. 2147483647 
  4. InputStr=2147483647 
  5. ResultInt=2147483647 

7.输入字符串为“2147483648”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. 2147483648 
  4. InputStr=2147483648 
  5. 2147483648 is bigger than INT_MAX(2147483647), please check! 

8.输入字符串为“123456789012”时,程序运行情况如下:

  1. Max value of int is 2147483647 
  2. Please input the string: 
  3. 123456789012 
  4. InputStr=123456789012 
  5. 123456789012 is bigger than INT_MAX(2147483647), please check! 

可见,对于上面考虑到的几种特殊情况,程序均能做出正确的处理。

六、需求扩展

基于本文中的需求和程序,我们可考虑对需求进行以下扩展:

1.不限制输入的字符串中只能包含数字,也可以在开头包含“+”或“-”。如果字符串是以“+”开头,那么***输出的整数是正整数;如果字符串是以“-”开头,那么***输出的整数是负整数。

 

2.如果输入的数字串大于了“2147483647”,那么程序直接输出整数值为2147483647。

【本文是51CTO专栏作者周兆熊的原创文章,作者微信公众号:周氏逻辑(logiczhou)】

戳这里,看该作者更多好文

责任编辑:赵宁宁 来源: 51CTO专栏
相关推荐

2016-12-30 13:32:24

字符串算法代码

2016-12-29 17:14:41

回文串算法代码

2016-12-30 13:37:50

字符串算法代码

2016-12-29 15:58:00

字符串子串算法

2016-12-29 17:07:59

字符算法代码

2023-02-26 22:33:32

字符串排列算法

2009-08-11 10:26:49

C#算法C#字符串反转

2021-09-03 09:41:36

字符串时间复杂度

2023-12-15 10:27:01

暴力匹配算法Python字符串

2013-05-06 10:54:08

字符串字符串匹配KMP算法

2021-12-29 16:40:54

Python语言字符串

2010-11-26 09:51:54

MySQL字符串

2023-04-11 08:54:57

字符串匹配算法

2024-02-19 15:38:08

JsonPython字符串

2009-12-01 14:00:37

PHP字符串转换为数值

2021-09-10 08:31:54

翻转字符串单词

2013-05-06 10:49:21

Boyer-Moore算法字符串匹配

2021-11-29 08:49:37

字符串转换整数

2024-03-12 07:35:39

Python字符串列表

2010-11-26 14:09:32

MySQL内置函数
点赞
收藏

51CTO技术栈公众号