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

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

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

一、需求描述

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

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

[[180304]]

二、算法設(shè)計(jì)

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

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

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

圖1 程序的總體流程

三、特殊流程考慮

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

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

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

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

四、程序代碼

  1. /********************************************************************** 
  2. * 版權(quán)所有 (C)2016, Zhou Zhaoxiong。 
  3. * 文件名稱: StrToInt.c 
  4. * 文件標(biāo)識(shí): 無 
  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. * 修改日期        版本號(hào)     修改人            修改內(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.     // 計(jì)算字符串對應(yīng)的整數(shù)值 
  80.     iTestStrLen = strlen(szTestStr); 
  81.     iResultInt = 0
  82.     for (iPosFlag = 0; iPosFlag < iTestStrLen; iPosFlag ++) 
  83.     { 
  84.         iBitVal = szTestStr[iPosFlag] - '0';    // 計(jì)算每一位對應(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. * 修改日期          版本號(hào)         修改人          修改內(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. * 修改日期          版本號(hào)         修改人          修改內(nèi)容 
  141. * --------------------------------------------------------------- 
  142. * 20160218          V1.0       Zhou Zhaoxiong        創(chuàng)建 
  143. ***********************************************************************/ 
  144. INT32 CalIntVal(INT32 iBitLen) 
  145. {     
  146.     if (iBitLen == 1)   // 個(gè)位 
  147.     { 
  148.         return 1; 
  149.     } 
  150.     else 
  151.     { 
  152.         return 10 * CalIntVal(iBitLen-1); 
  153.     } 

五、程序測試

我們將編寫好的程序“StrToInt.c”上傳到Linux機(jī)器,并使用“gcc -g -o StrToIntStrToInt.c”命令對該程序進(jìn)行編譯,生成“StrToInt”文件。下面對程序進(jìn)行詳細(xì)的測試。

1.輸入字符串為“12345”時(shí),程序運(yùn)行情況如下:

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

2.輸入字符串為“-12345”時(shí),程序運(yùn)行情況如下:

  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”時(shí),程序運(yùn)行情況如下:

  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”時(shí),程序運(yùn)行情況如下:

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

5.輸入字符串為“0123450”時(shí),程序運(yùn)行情況如下:

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

6.輸入字符串為“2147483647”時(shí),程序運(yùn)行情況如下:

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

7.輸入字符串為“2147483648”時(shí),程序運(yùn)行情況如下:

  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”時(shí),程序運(yùn)行情況如下:

  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! 

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

六、需求擴(kuò)展

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

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

 

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

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

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

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

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#字符串反轉(zhuǎn)

2021-09-03 09:41:36

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

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

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

2016-12-29 16:25:32

字符串算法代碼

2009-12-01 14:00:37

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

2021-11-29 08:49:37

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

2024-03-12 07:35:39

Python字符串列表

2024-02-19 15:38:08

JsonPython字符串
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 国产特级毛片 | 99久久免费精品国产男女高不卡 | 一区二区三区不卡视频 | 6080亚洲精品一区二区 | 91视频在线观看 | 亚洲国产精品人人爽夜夜爽 | 国产高清在线精品一区二区三区 | 鲁大师一区影视 | 中文av在线播放 | 亚洲欧美日韩中文字幕一区二区三区 | 欧美一级片在线 | 日日草天天干 | 欧美成人一区二区三区 | av夜夜操| 亚洲精品成人网 | 亚洲第一福利视频 | 毛片一区二区三区 | 91一区二区三区 | 亚洲1区| 亚洲福利 | 欧美午夜视频 | 色婷婷一区二区三区四区 | 久久精品无码一区二区三区 | 不卡一区 | 久久中文字幕电影 | 在线欧美视频 | 国产精品成人一区二区三区夜夜夜 | 四虎影院免费在线播放 | 亚洲三级av| 国产一区二区三区在线视频 | 欧美精品乱码久久久久久按摩 | 免费视频久久 | 二区精品| 欧美成人免费在线视频 | 中文字幕在线观看一区 | 日韩中文字幕免费 | 亚洲天堂免费在线 | 日韩激情免费 | 最近最新中文字幕 | 成在线人视频免费视频 | 国产三区四区 |