全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1653
推到 Plurk!
推到 Facebook!

C++中最簡單的問題: 數字轉字串!!

尚未結案
kitsam
一般會員


發表:13
回覆:11
積分:4
註冊:2005-02-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-04-13 21:52:46 IP:222.166.xxx.xxx 未訂閱
大家好,如題,這是個非常簡單的問題,但在標準c++中我卻找不到一個清脆的解決方法(是只在標準c++,不是在bcb中)。 現在我找到的方法是用itoa,但這個函數必須放入一個buffer的char陣列,例如:  
char buff[50];
char *c=itoa(123,buff,10);
 
問題在於我不知到buffer應該用多大,太大而怕浪費,太小又怕不足夠,請問有沒有其他的函式能直接做轉換,就好像java中的Integer.toString(123)那樣,非常清脆利落呢!
supman
尊榮會員


發表:29
回覆:770
積分:924
註冊:2002-04-22

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-04-13 22:19:12 IP:203.204.xxx.xxx 未訂閱
您好: 有一個方式可以得知數字的長度,就是您可以設依各回圈,將數字每次都除以10 ,當他小於0時就是您的字元長度了. 然後再動態配置記憶體. char *buff; buff=new char[得到的長度]
暗黑破壞神
版主


發表:9
回覆:2301
積分:1627
註冊:2004-10-04

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-04-13 23:02:06 IP:221.169.xxx.xxx 未訂閱
狠一點先用 log 算出共有幾位。 還不用一位一位去除。 log 10 = 1 log 100 = 2 位數就可以這樣算出來了。
海星
高階會員


發表:41
回覆:217
積分:106
註冊:2003-01-09

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-04-14 08:13:14 IP:211.20.xxx.xxx 未訂閱
有那麼困難嗎??? 一個 long 值最大值是多少?? long longint 4 -2,147,483,647 to 2,147,483,647 所以你至多陣列也只需設定 12 個 byte, 設太多也沒用,根本就沒那麼大的數。 那既然這樣為何需要去困擾要設多大的陣列?12的bytes設1000次對你的系統記憶體也是不痛不癢完全不吃記憶體,所以你的陣列設死的就好,不需杞人天優 想那麼多。
系統時間:2024-05-19 14:18:55
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!