那誰的技術博客
感興趣領域:高性能服務器編程,存儲,算法,Linux內核
隨筆 - 210, 文章 - 0, 評論 - 1183, 引用 - 0
數據加載中……
常見排序算法的實現(二)-shell排序
shell排序是對插入排序的一個改裝,它每次排序把序列的元素按照某個增量分成幾個子序列,對這幾個子序列進行插入排序,然后不斷的縮小增量擴大每個子序列的元素數量,直到增量為一的時候子序列就和原先的待排列序列一樣了,此時只需要做少量的比較和移動就可以完成對序列的排序了.
//
?shell排序
void
?ShellSort(
int
?array[],?
int
?length)
{
????
int
?temp;
????
//
?增量從數組長度的一半開始,每次減小一倍
????
for
?(
int
?increment?
=
?length?
/
?
2
;?increment?
>
?
0
;?increment?
/=
?
2
)
????????
for
?(
int
?i?
=
?increment;?i?
<
?length;?
++
i)
????????
{
????????????temp?
=
?array[i];
????????????
//
?對一組增量為increment的元素進行插入排序
????????????
for
?(
int
?j?
=
?i;?j?
>=
?increment;?j?
-=
?increment)
????????????
{
????????????????
//
?把i之前大于array[i]的數據向后移動
????????????????
if
?(temp?
<
?array[j?
-
?increment])
????????????????
{
????????????????????array[j]?
=
?array[j?
-
?increment];
????????????????}
????????????????
else
????????????????
{
????????????????????
break
;
????????????????}
????????????}
????????????
//
?在合適位置安放當前元素
????????????array[j]?
=
?temp;
????????}
}
動畫演示:
http://202.113.89.254/DataStructure/DS/web/flashhtml/shell.htm
posted on 2006-07-03 16:07
那誰
閱讀(1070)
評論(0)
編輯
收藏
引用
所屬分類:
算法與數據結構
只有注冊用戶
登錄
后才能發表評論。
【推薦】100%開源!大型工業跨平臺軟件C++源碼提供,建模,組態!
相關文章:
[算法]如何根據數據的多種屬性來查找數據
Btree算法實現代碼
二分查找學習札記
把二分查找算法寫正確需要注意的地方
在一個有序序列中查找重復/不存在的數
自己實現的memcpy
另類的鏈表數據結構以及算法
memcached內存管理算法
二分查找算法(迭代和遞歸版本)
ccache發布0.5版本
網站導航:
博客園
IT新聞
BlogJava
博問
Chat2DB
管理
Powered by:
C++博客
Copyright © 那誰
導航
C++博客
首頁
聯系
聚合
管理
<
2011年6月
>
日
一
二
三
四
五
六
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
1
2
3
4
5
6
7
8
9
公告
常用鏈接
我的隨筆
我的評論
我參與的隨筆
留言簿
(71)
給我留言
查看公開留言
查看私人留言
隨筆分類
(264)
avidya(1)
(rss)
C\C++(21)
(rss)
ccache(8)
(rss)
CGL(5)
(rss)
eventrpc(1)
(rss)
gdb(2)
(rss)
libevent(2)
(rss)
lighttpd(10)
(rss)
linux kernel(7)
(rss)
Linux/Unix(32)
(rss)
memcached(2)
(rss)
mktags(4)
(rss)
Nginx(5)
(rss)
Perl(3)
(rss)
tokyo cabinet(5)
(rss)
操作系統(1)
(rss)
讀書筆記(3)
(rss)
服務器設計(42)
(rss)
腳本語言(1)
(rss)
經驗教訓(4)
(rss)
其他(10)
(rss)
設計模式(24)
(rss)
算法與數據結構(48)
(rss)
圖形學(1)
(rss)
網絡編程(22)
(rss)
隨筆檔案
(210)
2010年8月 (1)
2010年7月 (3)
2010年6月 (2)
2010年5月 (1)
2010年4月 (2)
2010年3月 (1)
2010年1月 (5)
2009年12月 (7)
2009年11月 (3)
2009年10月 (7)
2009年9月 (2)
2009年8月 (2)
2009年7月 (1)
2009年6月 (3)
2009年5月 (2)
2009年4月 (7)
2009年3月 (2)
2009年2月 (2)
2009年1月 (5)
2008年12月 (1)
2008年11月 (2)
2008年10月 (6)
2008年9月 (12)
2008年8月 (11)
2008年7月 (5)
2008年6月 (2)
2008年4月 (3)
2008年3月 (3)
2008年2月 (1)
2008年1月 (1)
2007年12月 (3)
2007年11月 (3)
2007年8月 (1)
2007年7月 (2)
2007年6月 (2)
2007年5月 (9)
2007年4月 (1)
2007年3月 (8)
2007年2月 (3)
2007年1月 (5)
2006年12月 (4)
2006年11月 (3)
2006年10月 (5)
2006年9月 (4)
2006年8月 (13)
2006年7月 (28)
2006年4月 (1)
2006年3月 (4)
2006年2月 (4)
2006年1月 (1)
2005年12月 (1)
相冊
ccache
lighttpd
tokyo cabinet
文件
關于我
我的google reader share
我的google reader share
開源項目
libevent
lighttpd
memcached
PCRE for Windows (Win32)
sqlite
STLFilt
論壇
ChinaUnix
OldLinux
朋友
cugb_cat
Edengundam
win_hate
ypxing
老羅
搜索
最新評論
1.?re: memcached采用的網絡模型
很好的文章,值得分享。
--紐約網站設計
2.?re: 常見設計模式的解析和實現(C++)文檔及源碼打包下載
評論內容較長,點擊標題查看
--殘陽叢林
3.?re: libevent事件處理框架分析
@hailong
拿走后,堆的恢復是logn
--jiao
4.?re: 從半同步-半異步模式談服務器的設計
學習服務器的一些代碼模式。
--王小亮
5.?re: 讓libevent支持多線程
剛開始以為有個新的方法可以實現多線程。。。。其實就試類似pipe的方式, memcache就是這樣做的,可以參考一下
--fly2010love
閱讀排行榜
1.?同步/異步與阻塞/非阻塞的區別(53106)
2.?libevent事件處理框架分析(45275)
3.?epoll學習筆記(41184)
4.?解讀google C++ code style談對C++的理解(38191)
5.?集成libevent,google protobuf的RPC框架(27508)
6.?常見設計模式的解析和實現(C++)文檔及源碼打包下載(24091)
7.?讓libevent支持多線程(23623)
8.?一個關于臨時對象和虛擬析構函數的問題(22339)
9.?epoll為什么這么快(20317)
10.?二叉樹遍歷算法集合(前中后序遍歷的遞歸和非遞歸算法,層序遍歷算法)(20253)
11.?Callback在C\C++中的實現(20177)
12.?二分查找算法(迭代和遞歸版本)(18345)
13.?談目前項目組的代碼提交制度(18001)
14.?Linux下面的線程鎖,條件變量以及信號量的使用(15688)
15.?C++的流設計很糟糕(14826)
16.?二分查找學習札記(14309)
17.?memcached采用的網絡模型(13975)
18.?紅黑樹的實現源碼(第二次修訂版)(13703)
19.?多進程服務器中,epoll的創建應該在創建子進程之后(12726)
20.?第一個socket程序-C\S模式的文件傳輸程序(12290)
21.?使用tolua++創建基于C\C++語言的lua腳本(12103)
22.?博客遷移(11722)
23.?從半同步-半異步模式談服務器的設計(11619)
24.?Lighty與Nginx的比較分析(11593)
25.?Btree算法實現代碼(11587)
26.?向德國人低頭(11559)
27.?epoll相關資料整理(11293)
28.?把二分查找算法寫正確需要注意的地方(11167)
29.?程序設計經驗總結(10268)
30.?我的項目Makefile文件模板(10191)
31.?帶超時機制的DNS解析API(9586)
32.?方法與工具(9424)
33.?自己設想的一個IM服務器的架構(9209)
評論排行榜
1.?常見設計模式的解析和實現(C++)文檔及源碼打包下載(90)
久久综合给久久狠狠97色
|
狠狠色丁香久久综合婷婷
|
青青草原综合久久
|
国产精品岛国久久久久
|
99热热久久这里只有精品68
|
精品熟女少妇av免费久久
|
国产产无码乱码精品久久鸭
|
久久综合九色综合网站
|
久久亚洲精品无码AV红樱桃
|
久久综合九色综合网站
|
久久久久九国产精品
|
久久人人爽人人爽人人AV
|
精品久久久久久99人妻
|
91久久婷婷国产综合精品青草
|
岛国搬运www久久
|
久久精品国产99国产精品导航
|
一本大道加勒比久久综合
|
国产精品美女久久久m
|
久久久高清免费视频
|
午夜精品久久久久成人
|
无码精品久久一区二区三区
|
99久久国产综合精品五月天喷水
|
久久福利青草精品资源站
|
久久久久一本毛久久久
|
国产免费久久久久久无码
|
国产产无码乱码精品久久鸭
|
色欲久久久天天天综合网精品
|
伊人久久大香线蕉无码麻豆
|
93精91精品国产综合久久香蕉
|
国产精品久久久久久福利69堂
|
A级毛片无码久久精品免费
|
无码任你躁久久久久久老妇App
|
少妇久久久久久被弄到高潮
|
性欧美大战久久久久久久
|
久久人人爽人人爽人人片AV高清
|
日产精品99久久久久久
|
国产精品青草久久久久婷婷
|
狠狠色婷婷久久综合频道日韩
|
中文精品久久久久人妻不卡
|
久久精品国产一区
|
18岁日韩内射颜射午夜久久成人
|