XY
沒有任何借口
posts - 9, comments - 31, trackbacks - 0, articles - 0
C++博客
::
首頁
::
新隨筆
::
聯(lián)系
::
聚合
::
管理
反轉(zhuǎn)字符串
Posted on 2008-06-04 16:22
路緣
閱讀(9834)
評論(2)
編輯
收藏
引用
所屬分類:
C/C++
題目:
編寫函數(shù)reverse_string,它的原型如下:
void reverse_string(char *str);
函數(shù)把參數(shù)字符串中的字符串反向排列。請使用指針而不是數(shù)組下標,不要使用任何C函數(shù)庫中用于操縱字符串的函數(shù)。提示:不要聲明一個局部數(shù)組來臨時存儲參數(shù)字符串。
算法:
關(guān)于反轉(zhuǎn)字符串的方法很多。這里我給出我想到的一種算法。
/**/
/*
***********反轉(zhuǎn)字符串***********
*/
void
reverse_str(
char
*
str)
{
char
*
cp
=
str;
int
i
=
0
;
while
(
*
str
!=
'
\0
'
)
{
str
++
;
i
++
;
}
i
/=
2
;
str
--
;
while
(i
--
>
0
)
{
*
str
^=
*
cp;
*
cp
^=
*
str;
*
str
^=
*
cp;
str
--
;
cp
++
;
}
}
說明:
算法中運用了:
a ^ a = 0 和 a ^ 0 = a
的特性。以此來進行變量值的交換,可以避免使用額外的臨時變量。
Feedback
#
re: 反轉(zhuǎn)字符串
回復
更多評論
2012-11-15 22:28 by
周翀
三次異或可以互換兩個值,也可以毀掉兩個值,當它們相等的時候……
#
re: 反轉(zhuǎn)字符串
回復
更多評論
2017-09-29 22:46 by
路緣
@周翀
剛一看,嚇我一跳,以為一直認為的解法有問題。細想一下,值相等也無妨。當毀掉其中一個值后,再做異或,另一個值就會得到保留,做第3次計算,毀掉的那個值也被恢復了,所以沒有問題。
刷新評論列表
只有注冊用戶
登錄
后才能發(fā)表評論。
【推薦】100%開源!大型工業(yè)跨平臺軟件C++源碼提供,建模,組態(tài)!
相關(guān)文章:
算法:快速排序之python實現(xiàn)
算法:找出n個數(shù)中重復最多的10個數(shù)
反轉(zhuǎn)字符串
刪除字符串中的子串
得到字符串S1中第一個且是字符串S2中的位置指針
網(wǎng)站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 路緣
日歷
<
2025年8月
>
日
一
二
三
四
五
六
27
28
29
30
31
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
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(5)
給我留言
查看公開留言
查看私人留言
隨筆分類
(9)
C/C++(5)
計算機圖形學(1)
數(shù)字圖像
網(wǎng)絡通信
系統(tǒng)體系(2)
移動開發(fā)(1)
隨筆檔案
(9)
2017年9月 (2)
2008年10月 (2)
2008年9月 (1)
2008年7月 (1)
2008年6月 (3)
博客
本人博客園的博客
搜索
積分與排名
積分 - 36389
排名 - 574
最新評論
1.?re: 反轉(zhuǎn)字符串
@周翀
剛一看,嚇我一跳,以為一直認為的解法有問題。細想一下,值相等也無妨。當毀掉其中一個值后,再做異或,另一個值就會得到保留,做第3次計算,毀掉的那個值也被恢復了,所以沒有問題。
--路緣
2.?re: 反轉(zhuǎn)字符串
三次異或可以互換兩個值,也可以毀掉兩個值,當它們相等的時候……
--周翀
3.?re: 深入理解計算機系統(tǒng)1_程序是如何運行的
抄襲
--圖—圖—
4.?re: 刪除字符串中的子串
ssize_t是什么類型?
--sb
5.?re: 刪除字符串中的子串
看錯了~~sorry
--ff
閱讀排行榜
1.?反轉(zhuǎn)字符串(9834)
2.?深入理解計算機系統(tǒng)1_程序是如何運行的(7978)
3.?刪除字符串中的子串(6664)
4.?分形的樂趣之_Hilbert曲線(2129)
5.?深入理解計算機系統(tǒng)2_信息存儲(2096)
評論排行榜
1.?刪除字符串中的子串(14)
2.?深入理解計算機系統(tǒng)1_程序是如何運行的(12)
3.?反轉(zhuǎn)字符串(2)
4.?分形的樂趣之_Hilbert曲線(2)
5.?symbian應用程序開發(fā)1(1)
一本一本久久aa综合精品
|
久久99国产精品久久99果冻传媒
|
99精品国产综合久久久久五月天
|
久久精品国产69国产精品亚洲
|
亚洲精品乱码久久久久久按摩
|
久久香蕉国产线看观看猫咪?v
|
亚洲精品无码久久久久sm
|
久久精品一本到99热免费
|
人妻无码久久精品
|
欧美日韩精品久久久久
|
久久精品国产精品亚洲人人
|
色综合久久最新中文字幕
|
一本久久a久久精品综合夜夜
|
99久久精品免费看国产一区二区三区
|
久久国产精品99精品国产
|
九九久久99综合一区二区
|
国产精品成人精品久久久
|
久久久人妻精品无码一区
|
午夜精品久久久久
|
久久A级毛片免费观看
|
久久精品国产精品青草
|
国产精品九九久久免费视频
|
久久国产精品无码网站
|
国色天香久久久久久久小说
|
无码国内精品久久综合88
|
久久无码专区国产精品发布
|
久久人爽人人爽人人片AV
|
久久99国产精一区二区三区
|
A级毛片无码久久精品免费
|
国内精品伊人久久久久妇
|
天天爽天天狠久久久综合麻豆
|
国产精品久久久久久吹潮
|
日韩一区二区久久久久久
|
久久精品国产精品亚洲人人
|
亚洲αv久久久噜噜噜噜噜
|
狠狠色伊人久久精品综合网
|
四虎国产精品成人免费久久
|
久久这里只有精品首页
|
久久综合九色综合网站
|
九九99精品久久久久久
|
久久九九兔免费精品6
|