那谁的技术博客
感兴趣领域:高性能服务器编程,算法,Linux内核
C++博客
首页
新随笔
联系
聚合
管理
随笔-174 评论-598 文章-0 trackbacks-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
那谁
阅读(691)
评论(0)
编辑
收藏
引用
所属分类:
算法与数据结构
标题
姓名
主页
验证码
*
内容(提交失败后,可以通过“恢复上次提交”恢复刚刚提交的内容)
Remember Me?
登录
使用高级评论
新用户注册
返回页首
恢复上次提交
[使用Ctrl+Enter键可以直接提交]
.NET频道
博客园社区
闪存
相关文章:
自己实现的memcpy
另类的链表数据结构以及算法
memcached内存管理算法
二分查找算法(迭代和递归版本)
ccache发布0.5版本
红黑树的实现源码(第二次修订版)
ccache发布0.4版本
(算法导论习题解exercise2.3-4)递归版插入排序
(算法导论习题解problem2.4)寻找一个序列中逆序对的数量
(算法导论习题解exercise2.3-7)给定一个整数序列以及一个数X,确定该序列中是否有两个数的和为X
网站导航:
博客园
BlogJava
博客生活
IT博客网
C++博客
PHP博客
博客园社区
管理
<
2006年7月
>
日
一
二
三
四
五
六
25
26
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
常用链接
我的随笔
我的评论
我参与的随笔
留言簿
(42)
给我留言
查看公开留言
查看私人留言
随笔分类
(207)
C\C++(18)
ccache(5)
CGL(5)
libevent(2)
linux kernel(6)
Linux/Unix(32)
memcached(1)
mktags(3)
Perl(3)
操作系统(1)
读书笔记(3)
服务器设计(33)
脚本语言(1)
其他(5)
设计模式(24)
算法与数据结构(43)
图形学(1)
网络编程(21)
随笔档案
(174)
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)
相册
文件
开源项目
libevent
lighttpd
memcached
PCRE for Windows (Win32)
sqlite
STLFilt
论坛
ChinaUnix
OldLinux
朋友
cugb_cat
Edengundam
win_hate
ypxing
老罗
收藏
Dictionary of Algorithms and Data Structures
unixtoolbox
最新随笔
1. mktags0.3版本发布--支持指定某个目录的搜索深度
2. 用gdb跟踪函数栈桢的变化情况
3. mktags0.2版本发布
4. mktags--根据指定的文件路径以及文件类型生成ctags以及cscope索引文件的工具
5. 同步/异步与阻塞/非阻塞的区别
6. linux内核V2.6.11学习笔记(6)--中断处理
7. linux内核V2.6.11学习笔记(5)--异常处理
8. linux内核V2.6.11学习笔记(4)--中断与异常处理概述
9. connect的两种出错情况
10. linux内核V2.6.11学习笔记(3)--switch_to宏
搜索
积分与排名
积分 - 260738
排名 - 7
最新随笔
1. mktags0.3版本发布--支持指定某个目录的搜索深度
2. 用gdb跟踪函数栈桢的变化情况
3. mktags0.2版本发布
4. mktags--根据指定的文件路径以及文件类型生成ctags以及cscope索引文件的工具
5. 同步/异步与阻塞/非阻塞的区别
6. linux内核V2.6.11学习笔记(6)--中断处理
7. linux内核V2.6.11学习笔记(5)--异常处理
8. linux内核V2.6.11学习笔记(4)--中断与异常处理概述
9. connect的两种出错情况
10. linux内核V2.6.11学习笔记(3)--switch_to宏
最新评论
1. re: epoll为什么这么快
比喻很形象,如果能再加上一些测试数据就好了
--liang
2. re: 常见设计模式的解析和实现(C++)之一-Factory模式[未登录]
没有具体的实用例子,没意思
--canaan
3. re: 用gdb跟踪函数栈桢的变化情况
评论内容较长,点击标题查看
--zuhd
4. re: 卖书
刷过上条评论,省得都加我QQ来了。。。
--DebiaX
5. re: 第一个socket程序-C\S模式的文件传输程序
真是太好了。
--faileast
阅读排行榜
1. epoll学习笔记(8034)
2. 常见设计模式的解析和实现(C++)文档及源码打包下载(5862)
3. 二叉树遍历算法集合(前中后序遍历的递归和非递归算法,层序遍历算法)(4006)
4. [算法]红黑树的实现代码(修订版)(3633)
5. 使用tolua++创建基于C\C++语言的lua脚本(3571)
6. libevent事件处理框架分析(3483)
7. epoll为什么这么快(3452)
8. 红黑树的实现源码(第二次修订版)(3428)
9. 第一个socket程序-C\S模式的文件传输程序(3232)
10. P2P原理的解释与实现(3029)
11. [数据结构]红黑树的实现源码(3020)
12. epoll相关资料整理(2932)
13. lighttpd1.4.18代码分析(一)--watcher,worker模型(2909)
14. 我的项目Makefile文件模板(2906)
15. 程序设计经验总结(2849)
16. 探索C++的秘密之一详解extern "C"(2837)
17. Linux下面的线程锁,条件变量以及信号量的使用(2825)
18. 研究了一下SGI STL的内存算法(2817)
19. AVL树的实现代码(2807)
20. 发布我的开源cache库ccache(2806)
21. (C++)一个愚蠢的错误(2773)
22. 让libevent支持多线程(2771)
23. 自己设想的一个IM服务器的架构(2692)
24. ccache发布0.5版本(2579)
25. 自己设想的一个IM服务器的架构(续一)(2560)
26. 二分查找算法(迭代和递归版本)(2543)
27. 多进程服务器中,epoll的创建应该在创建子进程之后(2510)
28. 服务器公共库开发-内存池管理模块(2476)
29. 对一个服务器的几步优化(2436)
30. 两种网络数据格式的比较(2408)
31. 同步/异步与阻塞/非阻塞的区别(2403)
32. memcache内存池的设计原理(2265)
33. [算法]找出m个数中最小的n个数(2252)