一年十二月  誰主春秋
關注:基礎系統工程 密碼學 人工智能
C++博客
首頁
新隨筆
聯系
聚合
管理
隨筆-162 評論-223 文章-30 trackbacks-0
十進制整數千位分隔符
原題為某游戲公司的試題,大意如下:
寫一個千位分隔符算法,函數原型是
char * format_thousands_separator(unsigned long val);
要求實現效果是
1.
使用者不需要釋放返回的字符串指針
2.
支持最多調用
16
次而不返回
相同
指針地址。
可以用以下方法測試
printf("num1(%s), num2(%s), num3(%s)\n",
format_thousands_separator(0),
format_thousands_separator(123456),
format_thousands_separator(23456789));
注:要求寫出可編譯并可以運行通過的程序代碼。
經過修改后,我目前最簡潔的C代碼描述如下
1
char
*
format_thousands_separator(unsigned
long
val)
2
{
3
static
char
buf[
16
][
16
];
4
static
int
c
=
0
;
5
6
long
m, n
=
0
;
7
char
*
p
=
&
buf[c
++
%
16
][
15
];
8
*
p
=
'
\0
'
;
9
10
do
11
{
12
m
=
val
%
10
;
13
val
=
val
/
10
;
14
*--
p
=
'
0
'
+
m;
15
16
if
(val
&&
!
(
++
n
%
3
))
17
*--
p
=
'
,
'
;
18
19
}
while
(val);
20
21
return
p;
22
}
這里再稍作一下擴展,使之能支持負數,代碼描述如下
1
char
*
format_thousands_separator(
long
val)
2
{
3
static
char
buf[
16
][
16
];
4
static
int
c
=
0
;
5
6
long
m, n
=
0
;
7
char
*
p
=
&
buf[c
++
%
16
][
15
];
8
*
p
=
'
\0
'
;
9
10
do
11
{
12
m
=
val
%
10
;
13
val
=
val
/
10
;
14
*--
p
=
'
0
'
+
(m
<
0
?
-
m : m);
15
16
if
(
!
val
&&
m
<
0
)
17
*--
p
=
'
-
'
;
18
19
if
(val
&&
!
(
++
n
%
3
))
20
*--
p
=
'
,
'
;
21
22
}
while
(val);
23
24
return
p;
25
}
如果哪位大俠有更簡潔高效的代碼,還望留言或Email我,謝謝哈
posted on 2011-06-24 10:55
春秋十二月
閱讀(2925)
評論(4)
編輯
收藏
引用
所屬分類:
Algorithm
評論:
#
re: 十進制整數千位分隔符 2011-06-24 17:45 |
4everlove
我認為這段代碼有一個問題,unsigned long的最大值為20位,從而有可能的分隔符位數為6,加上一個\0,那么一個數組應該保留27位才可能保證邊界安全
回復
更多評論
#
re: 十進制整數千位分隔符 2011-06-24 20:25 |
qinqing1984
@4everlove
呵呵,有道理
回復
更多評論
#
re: 十進制整數千位分隔符[未登錄] 2011-06-29 16:06 |
tom
為什么不調用C Runtime比如itoa()之類,然后對字符串進行操作?
回復
更多評論
#
re: 十進制整數千位分隔符[未登錄]
2011-12-06 13:30 |
x
這代碼雖然實現了,但是有Bug
回復
更多評論
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
關于分圓域的一般結論
一個歐拉數整除問題的兩種證法
有限域上的特征與指數和之擴展
二元二次型的相似變換、正定性與正交分解
關于群的一些結論及應用
不定方程的代數數論解法
關于橢圓曲線的驗證計算
不可約多項式判別算法的改正
論證有限域上平方根的求解
求解離散對數問題的Terr算法
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
本博客所有隨筆均為原創,因為不定期維護更新,所以轉載請注明出處,如有問題和建議,請留言或評論,發表您的寶貴意見,藉此平臺以分享交流、共同進步。
聯系方式:微信math-engineer
<
2013年3月
>
日
一
二
三
四
五
六
24
25
26
27
28
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(78)
給我留言
查看公開留言
查看私人留言
隨筆分類
(161)
Algorithm(49)
C/C++(24)
Compiler(25)
Compute Theory(5)
Database(4)
Network(17)
Opensrc(13)
System(24)
隨筆檔案
(162)
2025年7月 (1)
2025年6月 (2)
2025年4月 (2)
2024年12月 (1)
2024年11月 (1)
2024年9月 (1)
2024年8月 (2)
2024年6月 (1)
2024年5月 (1)
2024年4月 (1)
2024年3月 (2)
2024年2月 (2)
2023年12月 (1)
2023年11月 (2)
2023年10月 (2)
2023年9月 (37)
2021年12月 (1)
2021年10月 (1)
2021年9月 (1)
2021年2月 (1)
2020年5月 (3)
2020年4月 (1)
2019年11月 (4)
2019年7月 (1)
2018年11月 (1)
2017年12月 (1)
2016年12月 (1)
2016年11月 (2)
2016年10月 (1)
2016年9月 (1)
2016年8月 (3)
2016年7月 (4)
2016年5月 (1)
2015年10月 (2)
2015年9月 (1)
2015年6月 (2)
2015年5月 (3)
2015年2月 (1)
2015年1月 (1)
2014年12月 (2)
2014年4月 (2)
2014年3月 (1)
2014年1月 (1)
2013年10月 (1)
2013年9月 (1)
2013年8月 (3)
2013年5月 (1)
2013年3月 (1)
2012年11月 (1)
2012年9月 (3)
2012年8月 (1)
2012年7月 (1)
2012年6月 (5)
2012年5月 (3)
2011年12月 (5)
2011年11月 (1)
2011年10月 (5)
2011年8月 (7)
2011年7月 (6)
2011年6月 (6)
2010年6月 (1)
2009年12月 (1)
2009年8月 (1)
2009年7月 (1)
2009年6月 (1)
2009年4月 (3)
文章分類
(30)
詩詞作品集(30)
關注的開源項目
LLVM
編譯系統
nginx
高性能Web服務器
OpenSSL
密碼學庫
suricata
網絡IPS引擎
最新隨筆
1.?關于分圓域的一般結論
2.?一個歐拉數整除問題的兩種證法
3.?有限域上的特征與指數和之擴展
4.?二元二次型的相似變換、正定性與正交分解
5.?關于群的一些結論及應用
6.?不定方程的代數數論解法
7.?關于橢圓曲線的驗證計算
8.?不可約多項式判別算法的改正
9.?論證有限域上平方根的求解
10.?求解離散對數問題的Terr算法
積分與排名
積分 - 419541
排名 - 56
最新評論
1.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
很有前途和很有錢途啊。
--chipset
2.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
@chipset
是的
--春秋十二月
3.?re: 一種攔截Linux原始套接字IO的方法[未登錄]
工作是做網絡安全?
--chipset
4.?re: 一種使用函數指針實現狀態機的方法
函數指針實現狀態機
--linda
5.?re: 多標簽視圖類CTabView的設計實現
為啥代碼缺少一些呢,給新手個完整點的啊
--pekingliu
6.?re: 工作線程與消息循環
從消息隊列取出消息 mark了
--mmocake
7.?re: 一種簡單的跨平臺套接字管道
評論內容較長,點擊標題查看
--IT搬運工
8.?re: 一種簡單的跨平臺套接字管道
windows僅支持af_init和af_init6地址族有錯別字么?
af_init和af_init6
--IT搬運工
9.?re: Shell應用(8):使用awk定位反匯編輸出[未登錄]
厲害
--Chipset
10.?re: TCP分組丟失時的狀態變遷
不錯
--Binky
閱讀排行榜
1.?基于OpenSSL實現的安全連接(14033)
2.?字符串16進制顯示(12900)
3.?基于boost asio實現的ssl socket框架(12351)
4.?Linux套接字與虛擬文件系統(1):初始化和創建(8700)
5.?關于數據庫的一些學習研究心得(8137)
6.?使用CString GetBuffer自適應獲取計算機名稱(7992)
7.?使用正則表達式解析URL(7958)
8.?basic_string內存泄露問題之分析解決(7767)
9.?Shell應用(4): 使用sed刪除行尾的^M字符(7700)
10.?nginx iocp(1):tcp異步連接(7671)
評論排行榜
1.?basic_string內存泄露問題之分析解決(19)
2.?求單向鏈表倒序第m個元素(11)
3.?基于順序存儲實現的多叉樹(1):深度優先存儲(9)
4.?字符大小寫轉換(7)
5.?字符串16進制顯示(6)
6.?面向對象鎖框架的設計與實現(6)
7.?Shell應用(4): 使用sed刪除行尾的^M字符(5)
8.?使用正則表達式解析URL(5)
9.?工作線程與消息循環(5)
10.?十進制整數千位分隔符(4)
Powered by:
博客園
模板提供:
滬江博客
Copyright ©2025 春秋十二月
青草影院天堂男人久久
|
开心久久婷婷综合中文字幕
|
亚洲va中文字幕无码久久不卡
|
色综合久久久久无码专区
|
色综合久久88色综合天天
|
亚洲精品NV久久久久久久久久
|
久久国产高潮流白浆免费观看
|
久久久精品久久久久特色影视
|
久久久久亚洲AV无码网站
|
国产女人aaa级久久久级
|
日韩精品无码久久久久久
|
久久99精品九九九久久婷婷
|
香港aa三级久久三级
|
亚洲精品WWW久久久久久
|
国产精品内射久久久久欢欢
|
亚洲综合伊人久久综合
|
合区精品久久久中文字幕一区
|
欧美777精品久久久久网
|
久久久久人妻一区精品性色av
|
大香伊人久久精品一区二区
|
精品熟女少妇aⅴ免费久久
|
久久av无码专区亚洲av桃花岛
|
伊人久久成人成综合网222
|
久久精品国产一区二区
|
91久久九九无码成人网站
|
国产精品免费看久久久
|
996久久国产精品线观看
|
久久香蕉超碰97国产精品
|
色综合久久无码中文字幕
|
色婷婷综合久久久久中文一区二区
|
人妻无码精品久久亚瑟影视
|
狠狠色丁香婷综合久久
|
久久久国产打桩机
|
国产A级毛片久久久精品毛片
|
热RE99久久精品国产66热
|
日本加勒比久久精品
|
亚洲欧美另类日本久久国产真实乱对白
|
国产精品无码久久四虎
|
亚洲国产成人久久综合一区77
|
久久影视综合亚洲
|
2019久久久高清456
|