成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

【字符串處理算法】字符串轉換為整數的算法設計及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

字符串時間復雜度

2013-05-06 10:54:08

字符串字符串匹配KMP算法

2023-12-15 10:27:01

暴力匹配算法Python字符串

2021-12-29 16:40:54

Python語言字符串

2010-11-26 09:51:54

MySQL字符串

2023-04-11 08:54:57

字符串匹配算法

2013-05-06 10:49:21

Boyer-Moore算法字符串匹配

2021-09-10 08:31:54

翻轉字符串單詞

2021-11-29 08:49:37

字符串轉換整數

2024-02-19 15:38:08

JsonPython字符串

2009-12-01 14:00:37

PHP字符串轉換為數值

2024-03-12 07:35:39

Python字符串列表

2016-12-29 16:25:32

字符串算法代碼
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲视频一区在线观看 | 日本黄色的视频 | 嫩草视频网 | 九七午夜剧场福利写真 | 国产精品久久久久久久免费观看 | 日韩欧美一区二区在线播放 | 在线观看国产 | 午夜精品一区二区三区在线播放 | 欧美亚洲国产一区二区三区 | 亚洲精品在线免费 | 亚洲精品一区二区三区蜜桃久 | 91精品一区二区三区久久久久久 | 久久婷婷香蕉热狠狠综合 | 欧美电影免费观看高清 | 成人一区二区三区在线观看 | 少妇一级淫片aaaaaaaaa | 成人免费视频播放 | 久久ww| 天天天操 | 99精品免费久久久久久久久日本 | 国产精品精品视频 | 久久久激情 | 自拍偷拍亚洲视频 | 粉色午夜视频 | 国产精品一码二码三码在线 | 精品日韩一区二区 | 久久不卡日韩美女 | 亚洲欧美综合精品久久成人 | 国产日产精品一区二区三区四区 | 天堂成人国产精品一区 | 亚洲在线视频 | 精品视频在线观看 | 在线观看av网站永久 | 男女羞羞视频免费看 | 久草在线免费资源 | a国产一区二区免费入口 | 亚洲精品视频免费观看 | 久久精品1 | 午夜成人免费视频 | 中文字幕第二十页 | 午夜在线观看视频 |