歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux編程 >> Linux編程

C語言將字符串轉換成對應的數字(十進制、十六進制)

問題1:講一個十進制數字的字符串表示轉換成對應的整數。舉例:將“1234”轉換成整數1234.
  1. /*將字符串s轉換成相應的整數*/ 
  2. int atoi(char s[]) 
  3.     int i; 
  4.     int n = 0; 
  5.     for (i = 0; s[i] >= '0' && s[i] <= '9'; ++i) 
  6.     { 
  7.         n = 10 * n + (s[i] - '0'); 
  8.     } 
  9.     return n; 

    問題2:將一個十六進制數的字符串表示形式轉換成對應的整數。所謂的十六進制數的字符串形式是指字符串只包含'0'-'9'或者'a'-'z'或者'A'-'Z',前導“0x”或者“0X”是否出現都可以。

    要解決這個問題,還需要一個將大寫字母轉換成小寫字母的工具函數:

  1. /*將大寫字母轉換成小寫字母*/ 
  2. int tolower(int c) 
  3.     if (c >= 'A' && c <= 'Z') 
  4.     { 
  5.         return c + 'a' - 'A'; 
  6.     } 
  7.     else 
  8.     { 
  9.         return c; 
  10.     } 

    下面是轉換函數:

  1. //將十六進制的字符串轉換成整數 
  2. int htoi(char s[]) 
  3.     int i; 
  4.     int n = 0; 
  5.     if (s[0] == '0' && (s[1]=='x' || s[1]=='X')) //判斷是否有前導0x或者0X
  6.     { 
  7.         i = 2; 
  8.     } 
  9.     else 
  10.     { 
  11.         i = 0; 
  12.     } 
  13.     for (; (s[i] >= '0' && s[i] <= '9') 
  14. || (s[i] >= 'a' && s[i] <= 'z') || (s[i] >='A' && s[i] <= 'Z');++i) 
  15.     {  
  16.         if (tolower(s[i]) > '9')
  17.         { 
  18.             n = 16 * n + (10 + tolower(s[i]) - 'a'); 
  19.         } 
  20.         else 
  21.         { 
  22.             n = 16 * n + (tolower(s[i]) - '0'); 
  23.         } 
  24.     } 
  25.     return n; 
Copyright © Linux教程網 All Rights Reserved