自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

【字符串處理算法】字符串轉(zhuǎn)換為整數(shù)的算法設(shè)計及C代碼實現(xiàn)

開發(fā) 開發(fā)工具 算法
今天講一講字符串轉(zhuǎn)換為整數(shù)的算法設(shè)計及C代碼實現(xiàn)。

一、需求描述

輸入一個由數(shù)字構(gòu)成的字符串,編寫程序?qū)⒃撟址D(zhuǎn)換為整數(shù)并輸出。

例如,如果輸入的字符串是“12345”,那么輸出的整數(shù)是12345。注意,不要使用C語言的庫函數(shù)atoi。

[[180304]]

二、算法設(shè)計

我們都知道,如果給定一個整數(shù)123,那么其表示方法是:123=1*100+2*10+3。也就是說,一個整數(shù)是由其各位上的數(shù)字按照位數(shù)求和組成的。

因此,這個需求的解決方法很簡單,只要將字符串中的各位數(shù)字按照其位數(shù)相加就行了。在此過程中,要考慮一些特殊情況。

程序的總體流程如圖1所示。

圖1 程序的總體流程

三、特殊流程考慮

在編寫程序的過程中,我們要對輸入的數(shù)字串的長度及格式多做考慮,如:

1.如果輸入的字符串中包含了除數(shù)字之外的其它字符,那么程序直接返回,不進(jìn)行后續(xù)處理。

2.如果數(shù)字串是以一個或多個字符0開頭的,則要先將其去掉之后再進(jìn)行后續(xù)處理。

3.因為在C語言中,整型(int)所能表示的***數(shù)為2147483647,所以如果輸入的數(shù)字串大于了“2147483647”,那么程序直接返回,不進(jìn)行后續(xù)處理。

四、程序代碼

  1. /********************************************************************** 
  2. * 版權(quán)所有 (C)2016, Zhou Zhaoxiong。 
  3. * 文件名稱: StrToInt.c 
  4. * 文件標(biāo)識: 無 
  5. * 內(nèi)容摘要: 將字符串轉(zhuǎn)換為整數(shù) 
  6. * 其它說明: 例如, 將"123"轉(zhuǎn)換為123 
  7. * 當(dāng)前版本: V1.0 
  8. * 作    者: Zhou Zhaoxiong 
  9. * 完成日期: 20160218 
  10. **********************************************************************/ 
  11. #include <stdio.h> 
  12. #include <limits.h>   // 由于在代碼中使用了INT_MAX, 因此要包含該頭文件 
  13.  
  14.  
  15. // 重新定義數(shù)據(jù)類型 
  16. typedef signed   char  INT8; 
  17. typedef          int   INT32; 
  18. typedef unsigned int   UINT32; 
  19.  
  20.  
  21. // 函數(shù)聲明 
  22. INT32 CalIntVal(INT32 iBitLen); 
  23. INT32 JudgeIfOverFlow(INT8 *pszTestStr); 
  24.  
  25.  
  26. /********************************************************************** 
  27. * 功能描述: 主函數(shù) 
  28. * 輸入?yún)?shù): 無 
  29. * 輸出參數(shù): 無 
  30. * 返 回 值: 0-執(zhí)行成功   其它-執(zhí)行失敗 
  31. * 其它說明: 無 
  32. * 修改日期        版本號     修改人            修改內(nèi)容 
  33. * --------------------------------------------------------------------- 
  34. * 20160218        V1.0     Zhou Zhaoxiong        創(chuàng)建 
  35. ***********************************************************************/ 
  36. INT32 main() 
  37.     INT8   szInputStr[100] = {0}; 
  38.     INT8   szTestStr[100]  = {0}; 
  39.     INT32  iResultInt      = 0;    // 轉(zhuǎn)換之后的整數(shù)***支持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.     // 判斷輸入的字符串中是否有除數(shù)字之外的其它字符, 若有, 則直接退出 
  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.     // 計算字符串對應(yīng)的整數(shù)值 
  80.     iTestStrLen = strlen(szTestStr); 
  81.     iResultInt = 0
  82.     for (iPosFlag = 0; iPosFlag < iTestStrLen; iPosFlag ++) 
  83.     { 
  84.         iBitVal = szTestStr[iPosFlag] - '0';    // 計算每一位對應(yīng)的數(shù)字 
  85.         iResultIntiResultInt = iResultInt + iBitVal * CalIntVal(iTestStrLen-iPosFlag); 
  86.     } 
  87.  
  88.     printf("ResultInt=%d\n", iResultInt); 
  89.      
  90.     return 0;             
  91.  
  92.  
  93. /********************************************************************** 
  94. * 功能描述: 判斷輸入的字符串是否溢出 
  95. * 輸入?yún)?shù): pszTestStr-測試字符串 
  96. * 輸出參數(shù): 無 
  97. * 返 回 值: 1-溢出  0-未溢出 
  98. * 其它說明: 判斷字符串是否大于2147483647, 若是, 則溢出 
  99. * 修改日期          版本號         修改人          修改內(nèi)容 
  100. * --------------------------------------------------------------- 
  101. * 20160218          V1.0       Zhou Zhaoxiong        創(chuàng)建 
  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. * 功能描述: 求字符串中的每一位所對應(yīng)的整數(shù)值 
  136. * 輸入?yún)?shù): iBitLen-對應(yīng)整數(shù)的第多少位 
  137. * 輸出參數(shù): 無 
  138. * 返 回 值: 該位所對應(yīng)的整數(shù)值 
  139. * 其它說明: 無 
  140. * 修改日期          版本號         修改人          修改內(nèi)容 
  141. * --------------------------------------------------------------- 
  142. * 20160218          V1.0       Zhou Zhaoxiong        創(chuàng)建 
  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”命令對該程序進(jìn)行編譯,生成“StrToInt”文件。下面對程序進(jìn)行詳細(xì)的測試。

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! 

可見,對于上面考慮到的幾種特殊情況,程序均能做出正確的處理。

六、需求擴展

基于本文中的需求和程序,我們可考慮對需求進(jìn)行以下擴展:

1.不限制輸入的字符串中只能包含數(shù)字,也可以在開頭包含“+”或“-”。如果字符串是以“+”開頭,那么***輸出的整數(shù)是正整數(shù);如果字符串是以“-”開頭,那么***輸出的整數(shù)是負(fù)整數(shù)。

 

2.如果輸入的數(shù)字串大于了“2147483647”,那么程序直接輸出整數(shù)值為2147483647。

【本文是51CTO專欄作者周兆熊的原創(chuàng)文章,作者微信公眾號:周氏邏輯(logiczhou)】

戳這里,看該作者更多好文

責(zé)任編輯:趙寧寧 來源: 51CTO專欄
相關(guān)推薦

2016-12-30 13:32:24

字符串算法代碼

2016-12-29 17:14:41

回文串算法代碼

2016-12-29 17:07:59

字符算法代碼

2016-12-30 13:37:50

字符串算法代碼

2016-12-29 15:58:00

字符串子串算法

2023-02-26 22:33:32

字符串排列算法

2009-08-11 10:26:49

C#算法C#字符串反轉(zhuǎn)

2013-05-06 10:54:08

字符串字符串匹配KMP算法

2023-12-15 10:27:01

暴力匹配算法Python字符串

2021-09-03 09:41:36

字符串時間復(fù)雜度

2021-12-29 16:40:54

Python語言字符串

2010-11-26 09:51:54

MySQL字符串

2021-11-29 08:49:37

字符串轉(zhuǎn)換整數(shù)

2023-04-11 08:54:57

字符串匹配算法

2024-03-12 07:35:39

Python字符串列表

2013-05-06 10:49:21

Boyer-Moore算法字符串匹配

2021-09-10 08:31:54

翻轉(zhuǎn)字符串單詞

2009-12-01 14:00:37

PHP字符串轉(zhuǎn)換為數(shù)值

2024-02-19 15:38:08

JsonPython字符串

2024-07-03 11:23:14

點贊
收藏

51CTO技術(shù)棧公眾號