天天看點

c判斷字元串是不是數字_C語言字元串與整數之間的轉換,小白必會知識

在C語言中,我們經常面臨需要将字元串轉換為整型,以及将整型轉化為字元串的問題。将字元串轉換為整數的函數在stdlib.h中定義:

int atoi(const char *str);

atoi函數會跳過str中前面出現的空格,從第一個數字開始轉換。下面是我的實作:

c判斷字元串是不是數字_C語言字元串與整數之間的轉換,小白必會知識

要注意的幾點:

1.參數檢驗。始終要放在最開始,在輸入是指針的情況下,永遠不要忘記首先檢驗是否是NULL指針;

2.字元串開始處的空格(我還加入了制表符)要注意跳過;

3.符号,不要忘了數字字元串第一個字元可能出現加号和減号!

對于将數字轉換為字元串,c标準中并沒有定義(itoa隻是在一些編譯器中自己定義)。c标準中沒有定義的原因我覺得是數字轉成字元串可以使用sprintf格式化輸出函數來完成。當然我們可以自己編寫一個itoa函數。這裡的參數原型參照的是vc中定義的itoa:

c判斷字元串是不是數字_C語言字元串與整數之間的轉換,小白必會知識

當然,一般情況下我們使用sprintf就可以完成任務啦:

char num[32];

sprintf(num,"%d",12345);

c/c++中把字元串轉換成整數,把整數轉換成字元串

#include <stdlib.h>. 這個是頭檔案

long atoi(char *); 這個是把字元轉換整數

double atof(char *); 這個是轉換浮點

char itoa(int i); 把整數轉為字元串

部分網友寫的思路源碼,把整數換成字元,sign判斷正負數。

c判斷字元串是不是數字_C語言字元串與整數之間的轉換,小白必會知識

還有一個 ,這個函數有3個參數,第一轉換的數,第二是轉換後的字元,第三是進制,不過這個函數沒有把STRING倒序

c判斷字元串是不是數字_C語言字元串與整數之間的轉換,小白必會知識

下面這個用遞歸算法,解決倒序問題。VC6.0上測試也可用。

c判斷字元串是不是數字_C語言字元串與整數之間的轉換,小白必會知識

希望對你有幫助

繼續閱讀