一年十二月  誰(shuí)主春秋
關(guān)注:基礎(chǔ)系統(tǒng)工程 密碼學(xué) 人工智能
C++博客
首頁(yè)
新隨筆
聯(lián)系
聚合
管理
隨筆-162 評(píng)論-223 文章-30 trackbacks-0
十進(jìn)制整數(shù)千位分隔符
原題為某游戲公司的試題,大意如下:
寫(xiě)一個(gè)千位分隔符算法,函數(shù)原型是
char * format_thousands_separator(unsigned long val);
要求實(shí)現(xiàn)效果是
1.
使用者不需要釋放返回的字符串指針
2.
支持最多調(diào)用
16
次而不返回
相同
指針地址。
可以用以下方法測(cè)試
printf("num1(%s), num2(%s), num3(%s)\n",
format_thousands_separator(0),
format_thousands_separator(123456),
format_thousands_separator(23456789));
注:要求寫(xiě)出可編譯并可以運(yùn)行通過(guò)的程序代碼。
經(jīng)過(guò)修改后,我目前最簡(jiǎn)潔的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
}
這里再稍作一下擴(kuò)展,使之能支持負(fù)數(shù),代碼描述如下
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
}
如果哪位大俠有更簡(jiǎn)潔高效的代碼,還望留言或Email我,謝謝哈
posted on 2011-06-24 10:55
春秋十二月
閱讀(2925)
評(píng)論(4)
編輯
收藏
引用
所屬分類(lèi):
Algorithm
評(píng)論:
#
re: 十進(jìn)制整數(shù)千位分隔符 2011-06-24 17:45 |
4everlove
我認(rèn)為這段代碼有一個(gè)問(wèn)題,unsigned long的最大值為20位,從而有可能的分隔符位數(shù)為6,加上一個(gè)\0,那么一個(gè)數(shù)組應(yīng)該保留27位才可能保證邊界安全
回復(fù)
更多評(píng)論
#
re: 十進(jìn)制整數(shù)千位分隔符 2011-06-24 20:25 |
qinqing1984
@4everlove
呵呵,有道理
回復(fù)
更多評(píng)論
#
re: 十進(jìn)制整數(shù)千位分隔符[未登錄](méi) 2011-06-29 16:06 |
tom
為什么不調(diào)用C Runtime比如itoa()之類(lèi),然后對(duì)字符串進(jìn)行操作?
回復(fù)
更多評(píng)論
#
re: 十進(jìn)制整數(shù)千位分隔符[未登錄](méi)
2011-12-06 13:30 |
x
這代碼雖然實(shí)現(xiàn)了,但是有Bug
回復(fù)
更多評(píng)論
刷新評(píng)論列表
只有注冊(cè)用戶(hù)
登錄
后才能發(fā)表評(píng)論。
【推薦】100%開(kāi)源!大型工業(yè)跨平臺(tái)軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
關(guān)于分圓域的一般結(jié)論
一個(gè)歐拉數(shù)整除問(wèn)題的兩種證法
有限域上的特征與指數(shù)和之?dāng)U展
二元二次型的相似變換、正定性與正交分解
關(guān)于群的一些結(jié)論及應(yīng)用
不定方程的代數(shù)數(shù)論解法
關(guān)于橢圓曲線(xiàn)的驗(yàn)證計(jì)算
不可約多項(xiàng)式判別算法的改正
論證有限域上平方根的求解
求解離散對(duì)數(shù)問(wèn)題的Terr算法
網(wǎng)站導(dǎo)航:
博客園
IT新聞
BlogJava
博問(wèn)
Chat2DB
管理
本博客所有隨筆均為原創(chuàng),因?yàn)椴欢ㄆ诰S護(hù)更新,所以轉(zhuǎn)載請(qǐng)注明出處,如有問(wèn)題和建議,請(qǐng)留言或評(píng)論,發(fā)表您的寶貴意見(jiàn),藉此平臺(tái)以分享交流、共同進(jìn)步。
聯(lián)系方式:微信math-engineer
<
2011年12月
>
日
一
二
三
四
五
六
27
28
29
30
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
7
常用鏈接
我的隨筆
我的評(píng)論
我參與的隨筆
留言簿
(78)
給我留言
查看公開(kāi)留言
查看私人留言
隨筆分類(lèi)
(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)
文章分類(lèi)
(30)
詩(shī)詞作品集(30)
關(guān)注的開(kāi)源項(xiàng)目
LLVM
編譯系統(tǒng)
nginx
高性能Web服務(wù)器
OpenSSL
密碼學(xué)庫(kù)
suricata
網(wǎng)絡(luò)IPS引擎
最新隨筆
1.?關(guān)于分圓域的一般結(jié)論
2.?一個(gè)歐拉數(shù)整除問(wèn)題的兩種證法
3.?有限域上的特征與指數(shù)和之?dāng)U展
4.?二元二次型的相似變換、正定性與正交分解
5.?關(guān)于群的一些結(jié)論及應(yīng)用
6.?不定方程的代數(shù)數(shù)論解法
7.?關(guān)于橢圓曲線(xiàn)的驗(yàn)證計(jì)算
8.?不可約多項(xiàng)式判別算法的改正
9.?論證有限域上平方根的求解
10.?求解離散對(duì)數(shù)問(wèn)題的Terr算法
積分與排名
積分 - 419568
排名 - 56
最新評(píng)論
1.?re: 一種攔截Linux原始套接字IO的方法[未登錄](méi)
很有前途和很有錢(qián)途啊。
--chipset
2.?re: 一種攔截Linux原始套接字IO的方法[未登錄](méi)
@chipset
是的
--春秋十二月
3.?re: 一種攔截Linux原始套接字IO的方法[未登錄](méi)
工作是做網(wǎng)絡(luò)安全?
--chipset
4.?re: 一種使用函數(shù)指針實(shí)現(xiàn)狀態(tài)機(jī)的方法
函數(shù)指針實(shí)現(xiàn)狀態(tài)機(jī)
--linda
5.?re: 多標(biāo)簽視圖類(lèi)CTabView的設(shè)計(jì)實(shí)現(xiàn)
為啥代碼缺少一些呢,給新手個(gè)完整點(diǎn)的啊
--pekingliu
6.?re: 工作線(xiàn)程與消息循環(huán)
從消息隊(duì)列取出消息 mark了
--mmocake
7.?re: 一種簡(jiǎn)單的跨平臺(tái)套接字管道
評(píng)論內(nèi)容較長(zhǎng),點(diǎn)擊標(biāo)題查看
--IT搬運(yùn)工
8.?re: 一種簡(jiǎn)單的跨平臺(tái)套接字管道
windows僅支持af_init和af_init6地址族有錯(cuò)別字么?
af_init和af_init6
--IT搬運(yùn)工
9.?re: Shell應(yīng)用(8):使用awk定位反匯編輸出[未登錄](méi)
厲害
--Chipset
10.?re: TCP分組丟失時(shí)的狀態(tài)變遷
不錯(cuò)
--Binky
閱讀排行榜
1.?基于OpenSSL實(shí)現(xiàn)的安全連接(14033)
2.?字符串16進(jìn)制顯示(12900)
3.?基于boost asio實(shí)現(xiàn)的ssl socket框架(12351)
4.?Linux套接字與虛擬文件系統(tǒng)(1):初始化和創(chuàng)建(8702)
5.?關(guān)于數(shù)據(jù)庫(kù)的一些學(xué)習(xí)研究心得(8137)
6.?使用CString GetBuffer自適應(yīng)獲取計(jì)算機(jī)名稱(chēng)(7992)
7.?使用正則表達(dá)式解析URL(7958)
8.?basic_string內(nèi)存泄露問(wèn)題之分析解決(7767)
9.?Shell應(yīng)用(4): 使用sed刪除行尾的^M字符(7700)
10.?nginx iocp(1):tcp異步連接(7671)
評(píng)論排行榜
1.?basic_string內(nèi)存泄露問(wèn)題之分析解決(19)
2.?求單向鏈表倒序第m個(gè)元素(11)
3.?基于順序存儲(chǔ)實(shí)現(xiàn)的多叉樹(shù)(1):深度優(yōu)先存儲(chǔ)(9)
4.?字符大小寫(xiě)轉(zhuǎn)換(7)
5.?字符串16進(jìn)制顯示(6)
6.?面向?qū)ο箧i框架的設(shè)計(jì)與實(shí)現(xiàn)(6)
7.?Shell應(yīng)用(4): 使用sed刪除行尾的^M字符(5)
8.?使用正則表達(dá)式解析URL(5)
9.?工作線(xiàn)程與消息循環(huán)(5)
10.?十進(jìn)制整數(shù)千位分隔符(4)
Powered by:
博客園
模板提供:
滬江博客
Copyright ©2025 春秋十二月
久久久这里有精品
|
国内精品久久久久久麻豆
|
久久国产精品99精品国产
|
久久国产精品-久久精品
|
久久久久久国产精品无码下载
|
亚洲国产成人精品久久久国产成人一区二区三区综
|
国产成人AV综合久久
|
香蕉久久夜色精品国产2020
|
久久久久亚洲AV无码专区体验
|
久久国产成人
|
99久久这里只有精品
|
久久久国产视频
|
国产—久久香蕉国产线看观看
|
麻豆久久
|
亚洲国产成人久久综合碰碰动漫3d
|
99久久精品费精品国产一区二区
|
一本色道久久综合狠狠躁篇
|
久久中文字幕人妻熟av女
|
94久久国产乱子伦精品免费
|
久久香综合精品久久伊人
|
性做久久久久久久久久久
|
久久se精品一区二区影院
|
久久er国产精品免费观看2
|
亚洲综合伊人久久大杳蕉
|
久久影视综合亚洲
|
国内精品久久久久久久久电影网
|
亚洲精品成人网久久久久久
|
国产视频久久
|
欧美激情精品久久久久久久九九九
|
国产精品久久久亚洲
|
久久国产热精品波多野结衣AV
|
久久精品国产亚洲αv忘忧草
|
伊人热热久久原色播放www
|
国产亚洲精久久久久久无码AV
|
免费精品99久久国产综合精品
|
国产精品久久久久…
|
国产ww久久久久久久久久
|
91久久精品电影
|
一本久道久久综合狠狠躁AV
|
久久99热这里只有精品国产
|
伊人久久久AV老熟妇色
|